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Foreword 



rd , 



This Technical Specification has been produced by the 3 Generation Partnership Project (3 GPP). 

The contents of the present document are subject to continuing work within the TSG and may change following formal 
TSG approval. Should the TSG modify the contents of the present document, it will be re-released by the TSG with an 
identifying change of release date and an increase in version number as follows: 

Version x.y.z 

where: 

X the first digit: 

1 presented to TSG for information; 

2 presented to TSG for approval; 

3 or greater indicates TSG approved document under change control. 

y the second digit is incremented for all changes of substance, i.e. technical enhancements, corrections, 
updates, etc. 

z the third digit is incremented when editorial only changes have been incorporated in the document. 



Introduction 

MBMS is a point-to -multipoint service in which data is transmitted from a single source entity to multiple recipients. 
Transmitting the same data to multiple recipients allows network resources to be shared. 

The MBMS bearer service offers two modes: 

• Broadcast Mode. 

• Multicast Mode. 

MBMS user services can be built on top of the MBMS bearer service. The present document specifies two delivery 
methods for the MBMS user services: download and streaming. Examples of applications using the download delivery 
method are news and software upgrades. Delivery of live music is an example of an application using the streaming 
delivery method. 

There can be several MBMS user services. The objective of the present document is the definition of a set of media 
codecs, formats and transport/application protocols to enable the deployment of MBMS user services. The present 
document takes into consideration the need to maximize the reuse of components of already specified services like PSS 

and MMS. 
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1 Scope 



The present document defines a set of media codecs, formats and transport/application protocols to enable the 
deployment of MBMS user services over the MBMS bearer service within the 3GPP system. 

In this version of the specification, only MBMS download and streaming delivery methods are specified. The present 
document does not preclude the use of other delivery methods. 

The present document includes information applicable to network operators, service providers and manufacturers. 
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Definitions and abbreviations 



3.1 Definitions 

For the purposes of the present document, the terms and definitions given in 3GPP TR 21.905 [1] and the following 
apply: 

Broadcast session: See 3GPP TS 22.146 [2]. 

Forward Error Correction (FEC): in the context of MBMS, a FEC mechanism is used at the application layer to 
allow MBMS receivers to recover lost SDUs 

FLUTE channel: equivalent to an ALC/LCT channel 

An ALC/LCT channel is defined by the combination of a sender and an address associated with the channel by the 

sender (RFC 3926 [9]). 

Multicast joining: See 3GPP TS 22.146 [2]. 

Multicast session: See 3GPP TS 22.146 [2]. 

Multimedia Broadcast/Multicast Service (MBMS): See 3GPP TS 22.146 [2]. 

MBMS user services: MBMS User Service may use more than one Multimedia Broadcast/Multicast Service (bearer 
service) and more than one Broadcast and/or Multicast session 

See 3GPPTS 22.246 [3]. 

MBMS user service discovery/announcement: user service discovery refers to methods for the UE to obtain the list of 
available MBMS user services along with information on the user service and the user service announcement refers to 
methods for the MBMS service provider to make the list of available MBMS user services along with information on 
the user service available to the UE 

MBMS user service initiation: UE mechanisms to setup the reception of MBMS user service data 
The initiation procedure takes place after the discovery of the MBMS user service 

MBMS delivery method: mechanism used by a MBMS user service to deliver content 

An MBMS delivery method uses MBMS bearers in delivering content and may make use of associated procedures. 

MBMS download delivery method: delivery of discrete objects (e.g. files) by means of a MBMS download session 

MBMS streaming delivery method: delivery of continuous media (e.g. real-time video) by means of a MBMS 
streaming session 

MBMS download session: time, protocols and protocol state (i.e. parameters) which define sender and receiver 
configuration for the download of content files 

MBMS streaming session: time, protocols and protocol state (i.e. parameters) which define sender and receiver 
configuration for the streaming of content 

RTP Session: The RTP and RTCP traffic sent to a specific IP multicast address and port pair (one port each for RTP 
and RTCP) during the time period the session is specified to exist. An RTP session is used to transport a single media 
type (e.g. audio, video, or text). An RTP session may contain several different streams of RTP packets using different 
SSRCs. 

3.2 Abbreviations 

For the purposes of the present document, the following abbreviations apply: 

ALC Asynchronous Layered Coding 

APN Access Point Name 

AVC Advanced Video Coding 

BM-SC Broadcast-Multicast - Service Centre 
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CC Congestion Control 

ERT Expected Residual Time 

ESI Encoding Symbol ID 

FDT File Delivery Table 

EEC Forward Error Correction 

FLUTE File deLivery over Unidirectional Transport 

GGSN Gateway GPRS Serving Node 

GPRS General Packet Radio Service 

IP Internet Protocol 

LCT Layered Coding Transport 

MBMS Multimedia Broadcast/Multicast Service 

MIME Multipurpose Internet Mail Extensions 

MS Mobile Station 

MSK MBMS Service Key 

MTK MBMS Traffic Key 

MUK MBMS User Key 

NTP Network Time Protocol 

PSS Packet Switch Streaming 

PTM Point To Multipoint 

PTP Point To Point 

RTP Real-Time transport Protocol 

SBN Source Block Number 

SCT Sender Current Time 

SDP Session Description Protocol 

SNTP Simple Network Time Protocol 

TMGI Temporary Mobile Group Identity 

TOI Transport Object Identifier 

TSI Transport Session Identifier 

UDP User Datagram Protocol 

UE User Equipment 

URI Uniform Resource Identifier 

URL Uniform Resource Locator 

UTC Universal Time Coordinated 

XML extensible Markup Language 



4 MBMS system description 

4.1 MBMS functional layers 

Three distinct functional layers are defined for the delivery of MBMS-based service. They are Bearers, Delivery 
method and User service. Figure 1 depicts these layers with examples of bearer types, delivery methods and 
applications. 
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Bearers provide the mechanism by which IP data is transported. IVIBIVIS bearers as defined in 
3GPP TS 23.246 [4] and 3GPP TS 22.146 [3] are used to transport multicast and broadcast traffic 
in an efficient one-to-many manner and are the foundation of IVIBIVIS-based services. IVIBIVIS 
bearers may be used jointly with unicast PDP contexts in offering complete service capabilities. 
When delivering MBMS content to a receiving application one or more delivery methods are used. 
The delivery layer provides functionality such as security and key distribution, reliability control by 
means of forward-error-correction techniques and associated delivery procedures such as file- 
repair, delivery verification. Two delivery methods are defined, namely download and streaming. 
Delivery methods may be added beyond release 6. Delivery methods may use MBMS bearers 
and may make use of point-to-point bearers through a set of MBMS associated procedures. 
The MBMS User service enables applications. Different applications impose different 
requirements when delivering content to MBMS subscribers and may use different MBMS delivery 
methods. As an example a messaging application such as MMS would use the download delivery 
method while a streaming application such as PSS would use the streaming delivery method. 



Figure 1 : Functional Layers for MBMS User Service 



4.2 



MBMS User Service Entities 



Figure 2 shows the MBMS user service entities and their inter-relations. Relation cardinality is depicted as well. 
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Figure 2: Entities and Relations 

An MBMS user service is an entity that is used in presenting a complete service offering to the end-user and allowing 
him to activate or deactivate the service. It is typically associated with short descriptive material presented to the end- 
user, which would potentially be used by the user to decide whether and when to activate the offered service. 

A single service entity can contain multiple distinct multimedia objects or streams, which may need to be provided over 
various MBMS download or MBMS streaming sessions. A download session or a streaming session is associated with 
its MBMS bearers and a set of delivery method parameters specifying how content is to be received on the mobile side. 

A set of one or more MBMS bearers can be used for delivering data as part of an MBMS download or streaming 
session. As an example, the audio and visual part of video stream can be carried on separate MBMS bearers. However, 
it is recommendated to transfer MBMS download and/or streaming sessions, which belong to the same MBMS user 
service on the same MBMS bearer service. 

An MBMS bearer (identified by IP multicast address and APN) might be used in providing data to more than one 
MBMS download or streaming session (3GPP TS 22.246 [3], clause 5). 
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4.3 



MBMS bearer service architecture 



The MBMS Bearer Service Architecture is defined in 3GPP TS 23.246 [4]. The MBMS User Service interfaces to the 
MBMS system via 3 entities. 

• The BM-SC. 

• TheGGSN. 

• The UE. 

The BM-SC provides functions for MBMS user service provisioning and delivery to the content provider. It can also 
serve as an entry point for IP MBMS data traffic from the MBMS User Service source. 

The GGSN serves as an entry point for IP multicast traffic as MBMS data from the BM-SC. 

4.4 Functional Entities to support MBMS User Services 
4.4.1 MBMS User Service Architecture 

Figure 3 depicts the MBMS network architecture showing MBMS related entities involved in providing MBMS user 
services. 
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Figure 3: MBMS network architecture model 

MBMS User Service architecture is based on an MBMS receiver on the UE side and a BM-SC on the network side. 

The use of the Gmb and Gi interface in providing IP multicast traffic and managing MBMS bearer sessions is described 
in detailed in 3GPP TS 23.246 [4]. 

Details about the BM-SC functional entities are given in figure 4. 
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Figure 4: BM-SC sub-functional structure 

The Session and Transmission function is further subdivided into the MBMS DeHvery functions and the Associated 
Delivery functions. 

The BM-SC and UE may exchange service and content related information either over point-to-point bearers or MBMS 
bearers whichever is suitable. To that end the following MBMS procedures are provided: 

• User Service Discovery / Announcement providing service description material to be presented to the end-user 
as well as application parameters used in providing service content to the end-user. 

• MBMS-based deHvery of data/content from the BM-SC to the UE over IP multicast. 

- The data/content is optionally confidentiality and/or integrity protected 

- The data/content is optionally protected by an forward error correction code 

• Key Request and Registration procedure for receiving keys and key updates. 

• Key distribution procedures whereby the BM-SC distributes key material required to access service data and 
delivered content. 

• Associated Delivery functions are invoked by the UE in relation to the MBMS data transmission. The following 
associated delivery functions are available: 

- File repair for download delivery method used to complement missing data. 

- Delivery verification and reception statistics collection procedures. 

The interfaces between internal BM-SC functions are outside the scope of the present document. 
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A "Proxy and Transport function" may be located between the "Session and Transmission Function" and the GGSN. 
The "Proxy and Transport function" is transparent to the "Session and Transmission function". The 'Proxy and 
Transport' function is defined in sub-clause 5.1.3 of [4]. 

4.4.1a Content Provider / Multicast Broadcast Source 

The Content Provider/Multicast Broadcast Source may provide discrete and continuous media, as well as service 
descriptions and control data, to the BM-SC to offer services via MBMS broadcast- and multicast bearer services at a 
time. An MBMS User Service may use one or several MBMS delivery methods simultaneously. The Content 
Provider/Multicast Broadcast Source may also be a 3^*^ Party Content Provider/Multicast Broadcast Source. 

The Content Provider/Multicast Broadcast Source function may reside within the operator's network or may be 
provided from outside the operator's network. The Content Provider/Multicast Broadcast Source can also configure the 
Session and Transmission functions (e.g. delivery or associated delivery). The interface between the Content 
Provider/Multicast Broadcast Source and the BM-SC is outside the scope of the present document. 

4.4.2 MBMS Key Management Function 

The MBMS Key Management function is used for distributing MBMS keys (Key Distribution subf unction) to 
authorized UEs. Before the UE can receive MBMS keys, the UE needs to register to the Key Request subfunction of the 
Key Management function by indicating the MBMS User Service Id. Once registered, the UE can request missing 
MBMS keys from the BM-SC by indicating the specific MBMS key id. In order for the UE to stop the BM-SC to send 
MBMS key updates a deregistration with the MBMS User Service Id is needed. 

If the MBMS User Service does not require any MBMS data protection, then the UE shall not register for key 
management purposes. 

A detailed description of all key management procedures is provided in 3GPP TS 33.246 [20]. 

4.4.3 MBMS Session and Transmission Function 

The MBMS Session and Transmission function transfers the actual MBMS session data to the group of MBMS UEs. 
The MBMS Session and Transmission function interacts with the GGSN through the Gmb Proxy function to activate 
and release the MBMS transmission resources. 

The function contains the MBMS delivery methods, which use the MBMS bearer service for distribution of content. 
Further this function contains a set of Associated-Delivery Functions, which may be invoked by the UE in relation to 
the MBMS data transmission (e.g. after the MBMS data transmission). 

The BM-SC Session and Transmission function is further described in later clauses of the present document as well as 
in3GPPTS23.246[4]. 

MBMS user services data may be integrity and/or confidentiality protected as specified within 3GPP TS 33.246 [20], 
and protection is applied between the BM-SC and the UE. This data protection is based on symmetric keys, which are 
shared between the BM-SC and the UEs accessing the service. 

MBMS user services may also be protected against packet loss between BM-SC and UE using a forward error 
correction code. 

4.4.4 User Service Discovery / Announcement function 

The User Service Discovery / Announcement provides service description information, which may be delivered via the 
Session and Transmission function or via the Interactive Announcement function. This includes information, which is 
necessary to initiate an MBMS user service as described in sub-clause 5.3.1. Metadata for the service descriptions are 
described in sub-clause 5.2. 

4.4.5 Interactive Announcement Function 

An Interactive Announcement Function may offer alternative means to provide service descriptions to the UE using 
HTTP or be distributed through other interactive transport methods. 
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4.4.6 MBMS UE 

The MBMS UE hosts the MBMS User Services receiver function. The MBMS receiver function may receive data from 
several MBMS User Services simultaneously. According to the MBMS UE capabilities, some MBMS UEs may be able 
to receive data, belonging to one MBMS User Service from several MBMS Bearer Services simultaneously. The 
MBMS receiver function uses interactive bearers for user service initiation / termination, user service discovery and 
associated delivery procedures. 

In case the MBMS user service is secured, the UE needs one or more cryptographic MBMS service keys, therefore the 
UE requests the relevant cryptographic MBMS service keys using the BM-SC Key Request function. The received 
keys (i.e. MSK) are then used for securing the MBMS session. 

4.5 Usage of identity of IVIBIVIS session 

The Session Identity of the MBMS session is provided with the MBMS session start procedure from the BM-SC to the 
GGSN via the Gmb protocol in the MBMS Session Identity information element. The 'MBMS Session Identity' 
information element is specified in [77]. The size of the Session Identity field is 1 octet. The MBMS Session Identity is 
forwarded with the MBMS SESSION START REQUEST message through the system and received by the MBMS UE 
with the paging message. 

The usage of the MBMS Session Identity is optional. The MBMS Session Identity is only applicable to MBMS 
download delivery sessions. The MBMS transmission resources are activated as described in sub-clause 5.4. Each 
MBMS session of the MBMS User Service may be activated using a different MBMS session identifier. The MBMS 
UE determines, based on the MBMS Session Identity value, whether the files of the upcoming MBMS download 
session were already received. If the files have already been completely received, the MBMS UE does not respond to 
the notification of the MBMS Session. 

The association of MBMS Session Identities to files is determined by the BM-SC and communicated within the File 
Delivery Table. This association of a MBMS Session Identity to files is valid until a particular expiry time, also 
signalled within the File Delivery Table. If a UE has not received a File Delivery Table associating a given MBMS 
Session Identity to a specific file or set of files, or a previously received association has expired, then the UE shall 
assume that the MBMS Session Identity value is associated to new files which has not yet been received and shall 
respond as normal to MBMS notifications with that Session Identity value. 

A single MBMS Session Identity value may be associated with a single file or with a set of files. Once a MBMS 
Session Identity value has been associated with a particular file or a set of files, this association shall not be changed 
before the expiry of the validity time for that MBMS Session Identity value. In particular, a File Delivery Table 
including some files that has previously been associated with a particular Session Identity value must include all files 
previously associated with that value, even if it is not intended to include all the files within the MBMS transmission 
session. 

An FDT instance includes the MBMS Session Identity expiry time and associates the MBMS Session Identity expiry 
times with particular MBMS Session Identity values. 

If the MBMS Session Identity is used by the BM-SC, the BM-SC shall also provide the session repetition number of 
that MBMS transmission session on the Gmb interface. 

If the BM-SC starts using the MBMS Session Identity for one MBMS Bearer Service, the BM-SC may still decide not 
to use the MBMS Session Identity for a later MBMS transmission on that MBMS bearer service (e.g. when an MBMS 
session is transmitted only once). 

After determining that all files for a MBMS Session Identity value has been received, the UE shall not respond to 
MBMS notifications for the MBMS Bearer Service with that MBMS Session Identity value until the MBMS Session 
Identity is expired. 

The UE shall recover its interest in a given MBMS Session Identity value when the MBMS Session Identity validity 
time for that Session Identity value has expired. 

The BM-SC may send FDT instances on a separate transmission session or interleaved with other data packets of the 
same transmission session. An FDT instance may describe more files than the files to be transmitted over the same 
transmission session as that FDT instance. 
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4.6 Time Synchronization between the BM-SC and IVIBMS UEs 

A number of MBMS metadata fragments and File Delivery Table (FDT) contain NTP encoded time values. NTP uses 
UTC as reference time and is independent from time zones. In order to process the time information from the BM-SC 
correctly, the MBMS UEs shall be time synchronized with the BM-SC with a UE tolerance of 10 seconds. The BM-SC 
shall offer an SNTP time server. The MBMS UEs should use SNTP to synchronize the time with the BM-SC. The 
MBMS UE should not use the SNTP time synchronization service more often than once in 30 days to avoid scalability 
issues. 

The BM-SC shall support the SNTP anycast mode [84]. An anycast client in the MBMS UE sends a request to a 
designated IPv4 or IPv6 local broadcast address or multicast group address. One or more SNTP anycast servers reply 
and include a timestamp with their current time and its precision. BM-SC SNTP servers shall only respond if they have 
a valid synchronisation time and shall not leave the timestamp blank, such that the SNTP Leap Indicator (LI) field shall 
not use the value 3 (warning: unsynchronised). Any MBMS SNTP client shall perform use the anycast mode each time 
it performs SNTP synchronisation; the client does not need to keep server address state data and changes in the SNTP 
server addressing will not effect each subsequent synchronisation operation. 

For IPv4, the lANA has assigned the multicast group address 224.0. LI for NTP, which is used both by multicast 
servers and anycast clients. For IPv6, the lANA has assigned the multicast group address FF0X:0:0:0:0:0:0:10L These 
NTP assignments apply to SNTP usage as well. The SNTP server will join these IP Multicast groups. 



5 Procedures and protocol 

5.1 Introduction 

This clause specifies the MBMS User service procedures and protocols. 

5.2 User Service Discovery/Announcement 

5.2.1 Introduction 

User service discovery refers to methods for the UE to obtain a list of available MBMS user services or user service 
bundles along with information on the user services. Part of the information may be presented to the user to enable 
service selection. 

User service announcement refers to methods for the MBMS service provider to announce the list of available MBMS 
user services and user service bundles, along with information on the user services, to the UE. 

In order for the user to be able to initiate a particular service, the UE needs certain metadata information. The required 
metadata information is described in sub-clause 5.2.2. 

According to 3GPP TS 23.246 [4], in order for this information to be available to the UE operators/service providers 
may consider several service discovery mechanisms. User service announcement may be performed over a MBMS 
bearer or via other means. The download delivery method is used for the user service announcement over a MBMS 
bearer. The user service announcement mechanism based on the download delivery method is described in sub-clause 
5.2.3. The user service announcement using interactive announcement function is described in sub-clause 5.2.4. Other 
user service announcement and discovery mechanisms by other means than the download delivery method are out of 
scope of the present document. 

5.2.2 MBMS User Service Description Metadata Fragments 
5.2.2.1 Introduction 

MBMS User Service Discovery/ Announcement is needed in order to advertise MBMS Streaming and MBMS 
Download User Services and User Service Bundles in advance of, and potentially during, the User Service sessions 
described. The User Services are described by metadata (objects/files) delivered using the download delivery method as 
defined in clause 7 or using interactive announcement functions. 
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MBMS User Service Disco very/ Announcement involves the delivery of fragments of metadata to many receivers in a 
suitable manner. The metadata itself describes details of services. A metadata fragment is a single uniquely identifiable 
block of metadata. An obvious example of a metadata fragment would be a single SDP file (RFC 2327 [14]). 

The metadata consists of: 

• a metadata fragment object describing details of a single or a bundle of MBMS user services (defined in sub- 
clause 11.2); 

• a metadata fragment object(s) describing details of MBMS user service sessions (defined in sub-clause 7.3 and 

8.3); 

• a metadata fragment object(s) describing details of Associated delivery methods (defined in sub-clause 9.5); 

• a metadata fragment object(s) describing details of service protection (defined in sub-clause 1 1.3); 

• a metadata fragment object describing details of the FEC repair data stream. 
Metadata management information consists of: 

• a metadata envelope object(s) allowing the identification, versioning, update and temporal validity of a metadata 
fragment (defined in sub-clause 11.1). 

The metadata envelope and metadata fragment objects are transported as file objects in the same download session 
either as separate referencing files or as a single embedding file - see sub-clause 5.2.3.3). A single metadata envelope 
shall describe a single metadata fragment, and thus instances of the two are paired. An service announcement sender 
shall make a metadata envelope instance available for each metadata fragment instance. The creation and use of both 
an embedded envelope instance and a referenced envelope instance for a particular fragment instance is not 
recommended. 

The metadata envelope and metadata fragment objects may be compressed using the generic GZip algorithm 
RFC 1952 [42] as content/transport encoding for transmission. Where used over an MBMS bearer, this shall be 
according to Download delivery content encoding using FLUTE - see sub-clause 7.2.5. 
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Figure 5: Simple Description Data Model 

Figure 5 illustrates the simple data model relation between these description instances using UML [21] for a single User 
Service Bundle Description. 
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NOTE: "N" means any number in each instance. 

One MBMS User Service Bundle Description shall contain at least one User Service Description instances and may 
contain several. The User Service Bundle Description may refer to a single FEC Repair Stream Description. 

One MBMS User Service Description instance shall include at least one delivery method description instance. The 
delivery method description shall refer to one session description instance. 

The delivery method description may contain references to a service protection description and an associated delivery 
procedure description. Several delivery methods may reference the same service protection description. 

If the associated delivery procedure description is present in the user service description instance, it may be referenced 
by one or more delivery methods. 

An MBMS user service description allows the association of delivery methods to one or more access systems. The 
association is used to describe the use of separate access systems for the same MBMS user service. One delivery 
method may be offered throughout one or more radio access system. The use of separate MBMS bearer services for the 
same MBMS user service is described in sub-clause 5.1.5.2 of [4]. 

Multipart MIME may be used to concatenate the descriptions into one document for transport. 

5.2.2.2 Session Description 

One or more session descriptions are contained in one session description object. The session description instance shall 
be formatted according to the Session Description Protocol (SDP) [14]. Each session description instance must describe 
either one Streaming session or one FLUTE Download session. A session description for a Streaming session may 
include multiple media descriptions for RTF sessions. The sessionDescriptionURI references the session description 
object. The session description is specified in sub-clause 7.3 for the MBMS download delivery method and in subclause 
8.3 for the MBMS streaming delivery method. 

5.2.2.3 Associated Delivery Procedure Description 

The description and configuration of associated delivery procedures is specified in clause 9. The 
associatedProcedureDescriptionURI references the associated delivery procedure instance. 

An associated delivery procedure description may be delivered on a dedicated announcement channel and updated on a 
dedicated announcement channel as well as in-band with an MBMS download session. 

If an associated delivery procedure description for File-Repair operations is available, then the MBMS receiver may use 
the file repair service as specified in sub-clause 9.3. 

If an associated delivery procedure description for reception reporting is available, then the MBMS receiver shall 
provide reception reports as specified in sub-clause 9.4. 

5.2.2.4 Service Protection Description 

The security description fragment contains the key identifiers and procedure descriptions for one delivery method. 
When different delivery methods use the same security description, the same security description document is 
referenced from the different delivery method elements. 

The security description contains key identifiers and the server address to request the actual key material. To avoid 
overload situations, the same load balancing principles as in the associated delivery procedures are used. The key 
management server shall be selected as defined in sub-clause 9.3.5. The back-off time shall be determined as defined in 
sub-clause 9.3.4. 

The XML schema for the service protection description is defined in sub-clause 1 1.3. 



5.2.2.5 FEC Repair Stream Description 

The streaming delivery method" s FEC has separate stream for repair data, which is described by the FEC Repair Stream 
Description. The FEC Repair Stream Description shall be done using SDP [14]. This SDP file is referenced by the 
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bundleDescription element in the service description. The FEC Repair Stream described is common for all FEC 
protected packet flows within the MBMS User Service Bundle Description instance. 

5.2.3 User Service Announcement over a MBMS bearer 

5.2.3.1 General 

Both the metadata envelope and metadata fragment objects are transported as file objects in the same download session. 

To receive a Service Announcement User Service the client shall obtain the session parameters for the related MBMS 
download session transport. This may be using a separate Service Announcement session. 

NOTE: The user service announcements are not protected when sent over MBMS bearer. See 
3GPPTS 33.246 [20] 

5.2.3.2 Metadata Envelope Transport 

The metadata envelope object is transported as a file object in the same MBMS service announcement download 
session as its metadata fragment file object (i.e. in-band with the metadata fragment session). 

5.2.3.3 Metadata Envelope and Metadata Fragment Association with FLUTE 

The MBMS Download service announcement session FDT Instances provide URIs for each transported object. The 
metadata envelope metadataURI field shall use the same URI for the metadata fragment as is used in the FDT Instances 
for that metadata fragment file. Thus, the fragment can be mapped to its associated envelope in-band of a single MBMS 
download session. 

In the referencing case, each metadata envelope and corresponding metadata fragment shall be grouped together by the 
FDT using the grouping mechanism described by sub-clause 7.2.5. This reduces the complexity of requesting both 
fragment and envelope for each pair, thus it is recommended that only the metadata fragment (fileURI) be requested 
from the download client (which will result in both fragment and envelope being received using the grouping 
mechanism). 

5.2.4 User Service Announcement using Interactive Announcement 
Function 

User service descriptions may be transported to the UE using HTTP and other interactive transport methods. A BM-SC 
may provide the service descriptions on request. Further protocol specifications of interactive announcement functions 
are outside of the scope of this specification. 

Aggregated MBMS service announcement documents as specified in sub-clause 5.2.5 may be used with the interactive 
announcement functions. UEs shall support the disassembly of aggregated MBMS service announcement documents. 
UEs shall support Gzip decoding of MBMS service description objects for interactive transport (BM-SC use of Gzip is 
optional in accordance with sub-clause 5.2.2). 

The BM-SC may use Metadata Envelopes as described in clause 11.1, and UEs shall support their use with the 
Interactive Announcement Function. Where metadata envelopes are not used, only the latest delivery of a metadata 
fragment shall be used by the UE, and the BM-SC shall ensure timely, consistent, size-limited and secure delivery of 
metadata by means outside the scope of this document. 

5.2.5 User Service Announcement over point-to-point push bearers 
5.2.5.1 General 

User service announcement over point-to-point push bearers have several characteristics that differ from user service 
announcement over a MBMS bearer. It is not essential that the metadata envelope made available by the service 
announcement sender is transmitted to the MBMS terminal. In the case that both the metadata envelope and metadata 
fragment objects are transported, it is a limitation of the solution that the metadata fragment must either be embedded 
within the metadata envelope, or that the metadata fragment must be referenced by the metadata envelope and they are 
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both contained within a multipart MIME container. In either configuration, the both the metadata envelope and 
metadata fragment objects are transported as file objects in the same download session. 

This sub-clause covers both metadata transport and metadata fragmentation aspects of Service Announcement. Service 
Announcement over point-to-point push bearers is specified. 

NOTE: The user service announcements are not protected when sent over point-to-point push bearers. See 
3GPPTS 33.246 [20] 

5.2.5.2 Supported Metadata Syntaxes 

The supported metadata syntaxes are as defined in sub-clause 1 1 . 1 of this document. 

5.2.5.3 Consistency Control and Syntax Independence 

The consistency control and syntax independence is as defined in sub-clause 11.1 of this document. 

5.2.5.4 Metadata Envelope Definition 

The metadata envelope definition is as defined in sub-clause 1 1 . 1 of this document. 

5.2.5.5 Delivery of the Metadata Envelope 

An instance of metadata fragment shall either be embedded within the metadata envelope or be included in a multipart 
MIME container together with the envelope. The envelope and fragment are, by definition, transported together and in- 
band of the same transport session. 

The Metadata Envelope includes a reference (metadataURI) to the associated metadata fragment using the same URI as 
the fragment file is identified by in the Service Announcement. Thus, Metadata Envelope can be mapped to its 
associated metadata fragment. 

5.2.5.6 Metadata Envelope Transport 

The metadata envelope object is transported as a file object in the same MBMS service announcement download 
session as its metadata fragment file object (i.e. in-band with the metadata fragment session). 

5.2.5.7 User service announcement over SMS bearers 

User service announcements over SMS bearers are formatted according to the OMA Push OTA specification [79]. 

OTA-WSP shall be used over the SMS bearer. Application port addressing shall be used as specified in [79] . The 
appHcation ID to be used is 0x9023 as allocated by OMNA [85]. 

Either confirmed or unconfirmed push may be used. In either case, the primitive shall contain the Push Headers 
parameter. Within this parameter, the Content-Type header shall be included and the Content-Encoding header shall be 
included if GZip is used. 

5.2.5.8 User service announcement over HTTP push bearers 

User service announcements over HTTP push bearers are formatted according to the OMA Push OTA specification 
[79]. 

OTA-HTTP shall be used over the HTTP push bearer. Application port addressing shall be used as specified in [79]. 
The appHcation ID to be used is 0x9023 as allocated by OMNA [85]. 

The Content-Encoding header shall be included if GZip is used. 
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5.2.6 Metadata Fragment Encapsulation to aggregate Service 
Announcement Documents 

The present document defines a number of metadata fragments to describe MBMS user services. A metadata fragment 
is a single uniquely identifiable block of metadata. Generally, more than one metadata fragment is necessary to provide 
all necessary parameters to initiate an MBMS User Service. Typically, metadata fragments are provided in separate 
documents. Each metadata fragment is labelled with its MIME type. 

Multipart MIME may be used to encapsulate metadata fragments into an aggregate service announcement document. 
The aggregate document may contain metadata fragments of several MBMS user services. It is recommended, that any 
such aggregate service announcement document contains all the referenced metadata fragments of each MBMS user 
service description it contains (i.e. in the same multipart MIME structure). 

An aggregate service announcement document shall encapsulate metadata fragments according to RFC 2557 [37]. The 
first encapsulated file of an aggregate service announcement document is the root resource. The root resource shall be 
either an MBMS user service description or a metadata envelope (as a referencing index). The service description 
metadata is defined in sub-clause 5.2.2.4. The metadata envelope is defined in sub-clause 5.2.3.3. 

The type field of the multipart/related header shall be set to application/mbms-user-service-description-parameter in 
case the root resource is a user service description instance. The type field of the multipart/related header shall be set to 
application/mbms-envelope in case the root resource is a metadata envelope. 



5.3 



User Service Initiation/Termination 



5.3.1 



Initiation 



MBMS User Service initiation refers to UE mechanisms to set-up the reception of MBMS user service data. During the 
User Service Initiation procedure, a set of MBMS Bearers may be activated. The User Service Initiation procedure takes 
place after the discovery of the MBMS user service. 
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1. Initiate 
User Service X 
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2. IVBMS User Service Registration 



3. IVBMS activation Request 



3n. IVBMS activation Request 



Figure 6: Initiation of an MBMS User Service 

1 . The User Service Initiation Procedure is triggered and takes a User Service Description as input that has been 
obtained e.g. by executing the MBMS User Service discovery and announcement functions. 

2. The MBMS UE requests MBMS service keys, if security functions are activated for the MBMS User Service. 
The keys are sent to the UE, after the user is authorized to receive the MBMS service. The request shall be 
authenticated. Details on the MBMS User Service Registration procedure are described in 3GPP TS 33.246 
[20]. 
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3. The MBMS UE uses the MBMS activation procedure to activate the MBMS Bearer Service. The MBMS 

activation procedure is the MBMS Multicast Service activation procedure and the MBMS Broadcast activation 
procedure as defined in 3GPP TS 23.246 [4]. In case the MBMS Broadcast Mode is activated, there is no 
activation message sent from the UE to the BM-SC. The activation is locally in the UE. Note that the MBMS 
Bearer Services may already by active and in use by another MBMS User Service. 

3n. In case the MBMS User Service uses several MBMS Bearer Services, the User Service Description contains 
several description items. In that case, the MBMS receiver function repeats the activation procedure for each 
MBMS Bearer Service as described in 3. 

5.3.2 MBMS User Service termination procedure 

MBMS user service termination refers to the UE mechanisms to terminate the reception of MBMS user services. A set 
of MBMS Bearers may be deactivated during this procedure. 
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Figure 7: Termination of an MBMS user service 

1 . The User Service termination Procedure is triggered. A reference to the User Service to terminate is provided 
as parameter. 

2. The MBMS UE deregisteres the security association for the MBMS User Services. Details on the MBMS User 
Service Deregistration procedure are described in 3GPP TS 33.246 [20]. 

3. If no other MBMS User Service uses the MBMS Bearer service, the MBMS UE uses the MBMS deactivation 
procedure to deactivate the MBMS Bearer Services. The MBMS deactivation procedure represents the MBMS 
Multicast service deactivation procedure and the MBMS Broadcast deactivation procedure as described in 
3GPP TS 23.246 [4]. In case the MBMS Broadcast Mode is deactivated, there is no message sent to the 
BM-SC. The deactivation is only locally in the UE. 

3n. In case the MBMS User Service uses several Bearer Services, the UE repeats the deactivation procedure for 
each Bearer Service as described in 3. 

5.4 MBMS Data Transfer Procedure 

MBMS Data Transfer procedure refers to the network (and UE) mechanism to transfer (and receive) data for one 
MBMS User Service on one or several MBMS Bearer Services. 
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NOTE: Security related interactions are not depicted in the sequence. 

Figure 8: Procedure of MBMS Data Transfer 

1. The MBMS Delivery Method for the MBMS User Service is triggered by the MBMS User Service 
Provider. Note, details of the trigger are beyond of the present document. 

2. - 2n. The MBMS DeHvery function uses the MBMS Session Start Procedure to the GGSN, possibly through the 

Gmb Proxy function to activate all MBMS Bearer Services, which belong to the MBMS User Service. The 
MBMS Bearer service to be activated is uniquely identified by the TMGI. 

Note. MBMS Bearer services might be activated only to a subset of the available access systems (see 3GPP TS 
23.246 [4]). In case MBMS User Services or delivery methods are not available throughout all access 
systems, the BM-SC describes this transmission strategy in the MBMS User Service Description (see 
sub-clause 5.2.2). 

3. - 3n. The data of the MBMS user service are transmitted to all listening MBMS UEs. Several MBMS Bearer 

services may be used to transmit the MBMS user service data. MBMS user service data may be integrity 
and/or confidentiality protected. In case MBMS user service data are integrity and/or confidentiality 
protected, MBMS traffic keys are delivered simultaneously on the same or a different MBMS bearer. 

4. - 4n. The MBMS Delivery function uses the MBMS Session Stop procedure to trigger the GGSN, possibly 

through the Gmb Proxy function to release all MBMS Bearer Service for this User Service. A unique 
identifier for the MBMS Bearer service to be deactivated (i.e. the TMGI) is passed on as a parameter. 

5. In case associated delivery procedures are allowed or requested for an MBMS User Service, the MBMS UE 
sends an associated-delivery procedure request to the associated -delivery function. The BM-SC may 
authenticate the user. See 3GPP TS 33.246 [20]. The MBMS UE may need to wait a random time before it 
starts the associated delivery procedure according to clause 9. 



5.5 



IVIBMS Protocols 



Figure 9 illustrates the protocol stack used by MBMS User services. The grey-shaded protocols and functions are 
outside of the scope of the present document. MBMS security functions and the usage of HTTP-digest and SRTP are 
defined in 3GPP TS 33.246 [20]. 
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Figure 9: Protocol stack view of the MBMS User Services 



Introduction on Delivery Methods 



Two delivery methods are defined in the present document - the download delivery method and the streaming delivery 
method. MBMS delivery methods make use of MBMS bearers for content delivery but may also use the associated 
procedures defined in clause 9. 

Use of MBMS bearers by the download delivery method is described in clause 7. The File Repair Procedure and the 
Reception Reporting Procedure (described in clause 9) may be used by the download delivery method. 

Use of MBMS bearers by the streaming delivery method is described in clause 8. 



Download Delivery Method 



7.1 



Introduction 



MBMS download delivery method uses the FLUTE protocol (RFC 3926 [9]) when delivering content over MBMS 
bearers. Usage of FLUTE protocol is described in this clause. 

FLUTE is built on top of the Asynchronous Layered Coding (ALC) protocol instantiation (RFC 3450 [10]). ALC 
combines the Layered Coding Transport (LCT) building block [1 1], a congestion control building block and the 
Forward Error Correction (FEC) building block (RFC 3452 [12]) to provide congestion controlled reliable 
asynchronous delivery of content to an unlimited number of concurrent receivers from a single sender. As mentioned in 
(RFC 3450 [10]), congestion control is not appropriate in the type of environment that MBMS download delivery is 
provided, and thus congestion control is not used for MBMS download delivery. See figure 10 for an illustration of 
FLUTE building block structure. FLUTE is carried over UDP/IP, and is independent of the IP version and the 
underlying link layers used. 



ETSI 



3GPP TS 26.346 version 6.10.0 Release 6 



30 



ETSI TS 126 346 V6.10.0 (2007-10) 



FLUTE 



ALC 



LCT 



CC i FEC 



Figure 10: Building block structure of FLUTE 

ALC uses the LCT building block to provide in-band session management functionality. The LCT building block has 
several specified and under- specified fields that are inherited and further specified by ALC. ALC uses the FEC building 
block to provide reliability. The FEC building block allows the choice of an appropriate FEC code to be used within 
ALC, including using the no-code FEC code that simply sends the original data using no FEC coding. ALC is under- 
specified and generally transports binary objects of finite or indeterminate length. FLUTE is a fully- specified protocol 
to transport files (any kind of discrete binary object), and uses special purpose objects - the File Description Table 
(FDT) Instances - to provide a running index of files and their essential reception parameters in-band of a FLUTE 
session. 

7.2 FLUTE usage for MBMS download 

The purpose of download is to deliver content in files. In the context of MBMS download, a file contains any type of 
MBMS data (e.g. 3GPP file ( Audio A^ideo), Binary data. Still images. Text, Service Announcement metadata). 

In the present document the term "file" is used for all objects carried by FLUTE (with the exception of the FDT 
Instances). 

UE applications for MBMS user services built upon the download delivery method have three general approaches to 
getting files from the FLUTE receiver for a joined session: 

• Promiscuous: Instruct FLUTE to promiscuously receive all files available. Promiscuous reception can be 
suitable for single purpose sessions (generally with limited number and/or size of files) although uncertainty over 
the quality and content of files makes this approach generally undesirable. 

• One-copy: Instruct FLUTE to receive a copy of one or more specific files (identified by the fileURI) - and 
potentially leaving the session following reception of one copy of all the specified files. Specifying the download 
file ensures that the UE has an upper bound to the quantity of files downloaded. One-copy reception requires 
prior knowledge of the file identifiers (fileURIs). 

• Keep-updated: Instruct FLUTE to receive one or more specific files and continue to receive any updates to 
those files. As with one-copy, the keep-updated approach bounds the quantity of files downloaded and requires 
prior knowledge of the file identifiers. 

NOTE: The present document does not prevent or endorse changing download reception approach, and any 

related file list, during the life of the download session. Discovery of session content lists (including file 
lists) out-of-band of the delivery method sessions is beyond the scope of the present document. 

MBMS clients and servers supporting MBMS download shall implement the FLUTE specification (RFC 3926 [9]), as 
well as ALC (RFC 3450 [10]) and LCT (RFC 3451 [11]) features that FLUTE inherits. In addition, several optional and 
extended aspects of FLUTE ,as described in the following clauses, shall be supported. 

One FDT instance is typically bound to one MBMS transmission session. It is therefore recommended, that each 
MBMS transmission session should contain one or more repetitions of the same FDT instance. 
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7.2.1 Fragmentation of Files 



Fragmentation of files shall be provided by a blocking algorithm (which calculates source blocks from source files) and 
a symbol encoding algorithm (which calculates encoding symbols from source blocks). 



7.2.2 Symbol Encoding Algorithm 



The "Compact No-Code FEC scheme" - RFC 3452 [12] (FEC Encoding ID 0, also known as "Null-EEC") shall be 
supported. 

The 'MBMS FEC scheme' is described in sub-clause 7.2.12. 

A UE that supports MBMS User Services shall support a decoder for the 'MBMS FEC scheme'. 

If a UE that supports MBMS User Services receives a mathematically sufficient set of encoding symbols generated 
according to the encoder specification in Annex B for reconstruction of a source block then the decoder shall recover 
the entire source block. Note that the example decoder described in annex E fulfils this requirement. 



7.2.3 Blocking Algorithm 



In the case of the Compact No-Code FEC scheme [12] (FEC Encoding ID 0), then the "Algorithm for Computing 
Source Block Structure" described within the FLUTE specification (RFC 3926 [9]) shall be used. 

In the case of MBMS forward error correction, then the algorithm defined in Annex B shall be used. 

The values of A^, Z, T and A shall be set such that the sub-block size is less than 256KB. 

7.2.4 Congestion Control 

For simplicity of congestion control, FLUTE channelization shall be provided by a single FLUTE channel with single 
rate transport. 

7.2.5 Content Encoding of Files for Transport 

Files may be content encoded for transport, as described in [9], in the Download delivery method using the generic 
GZip algorithm RFC 1952 [42]. UEs shall support GZip content decoding of FLUTE files (GZIP RFC 1952 [42], 
clause 9). 

7.2.6 Transport File Grouping 

Files downloaded as part of a multiple-file delivery are generally related to one another. Examples include web pages, 
software packages, and the referencing metadata envelopes and their metadata fragments. FLUTE clients analyse the 
XML-encoded FDT Instances as they are received, identify each requested file, associate it with FLUTE packets (using 
the TGI) and discover the relevant in-band download configuration parameters of each file. 

An additional "group" field in the FLUTE FDT instance and file elements enables logical grouping of related files. A 
FLUTE receiver should download all the files belonging to all groups where one or more of the files of those groups 
have been requested. However, a UE may instruct its FLUTE receiver to ignore grouping to deal with special 
circumstances, such as low storage availability. 

The group names are allocated by the FLUTE sender and each specific group name shall group the corresponding files 
together as one group, including files describes in the same and other FDT Instances, for a session. 

Group field usage in FDT Instances is shown in the FDT XML schema (clause 7.2.10). Each file element of an FDT 
Instance may be labelled with zero, one or more group names. Each FDT Instance element may be labelled with zero, 
one or more group names which are inherited by all files described in that FDT Instance. 

7.2.7 Signalling of Parameters with Basic ALC/FLUTE Headers 

FLUTE and ALC mandatory header fields shall be as specified in [9, 10] with the following additional specializations: 
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• The length of the CCI (Congestion Control Identifier) field shall be 32 bits and it is assigned a value of zero 
(C=0). 

• The Transmission Session Identifier (TSI) field shall be of length 16 bits (S=0, H=l, 16 bits). 

• The Transport Object Identifier (TOI) field should be of length 16 bits (0=0, H=l). 

• Only Transport Object Identifier (TOI) (zero) shall be used for FDT Instances. 

• The following features may be used for signalling the end of session and end of object transmission to the 
receiver: 

- The Close Session flag (A) for indicating the end of a session. 

- The Close Object flag (B) for indicating the end of an object. 
In FLUTE the following applies: 

• The Sender Current Time present flag (T) shall be set to zero. 

• The Expected Residual Time present flag (R) shall be set to zero. 

• The LCT header length (HDR_LEN) shall be set to the total length of the LCT header in units of 32-bit words. 

• For "Compact No-Code EEC scheme" [12], the EEC Payload ID shall be set according to RFC 3695 [13] such 
that a 16 bit SBN (Source Block Number) and then the 16 bit ESI (Encoding Symbol ID) are given. 

• For 'MBMS EEC scheme', the EEC Payload ID shall be set according to Section 7.2.10 below. 

7.2.8 Signalling of Parameters with FLUTE Extension Headers 

FLUTE extension header fields EXT_FDT, EXT_FTI , EXT_CENC [9] shall be used as follows: 

• EXT_FTI shall be included in every FLUTE packet carrying symbols belonging to any FDT Instance. 

• FLUTE packets carrying symbols of files (not FDT Instances) shall not include an EXT_FTI. 

• FDT Instances shall not be content encoded and therefore EXT_CENC shall not be used. 
In FLUTE the following applies: 

• EXT_FDT is in every FLUTE packet carrying symbols belonging to any FDT Instance. 

• FLUTE packets carrying symbols of files (not FDT instances) do not include the EXT_FDT. 

7.2.9 Signalling of Parameters with FDT Instances 

The extended FLUTE FDT instance schema defined in clause 7.2.10.1 (based on the one in RFC 3926 [9]) shall be 
used. In addition, the following applies to both the session level information and all files of a FLUTE session. 

The inclusion of these FDT Instance data elements is mandatory according to the FLUTE specification: 

• Content-Location (URI of a file). 

• TOI (Transport Object Identifier of a file instance). 

• Expires (expiry data for the FDT Instance). 

Additionally, the inclusion of these FDT Instance data elements is mandatory. Note the following elements are optional 
in the FDT schema to stay aligned with the IETF RFC defined schema: 

• Content-Length (source file length in bytes). 

• Content-Type (content MIME type). 
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• FEC Encoding ID. 

Other FEC Object Transmission Information specified by the FEC scheme in use: 

NOTE: The FEC Object Transmission Information elements used are dependent on the FEC scheme, as indicated by 
the FEC Encoding ID. 

• FEC-OTI-Maximum-Source-Block-Length. 

• FEC-OTI-Encoding- Symbol-Length. 

• FEC-OTI-Max-Number-of-Encoding-Symbols. 

• FEC-OTI-Scheme-Specific-Info. 

NOTE 1: RFC 3926 [9] describes which part or parts of an FDT Instance may be used to provide these data 
elements. 

These optional FDT Instance data elements may or may not be included for FLUTE in MBMS: 

• Complete (the signalling that an FDT Instance provides a complete, and subsequently unmodifiable, set of file 
parameters for a FLUTE session may or may not be performed according to this method). 

• Content-Encoding. 

• Content-MD5: represents a digest of the transport object. The file server should indicate the MD5 hash value 
whenever multiple versions of the file are anticipated for the download session. 

NOTE 2: The values for each of the above data elements are calculated or discovered by the FLUTE sender. 

The FEC-OTI-Scheme-Specific-Info FDT Instance data element contains information specific to the FEC scheme 
indicated by the FEC Encoding ID encoded using base64. 
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7.2.10 FDT Schema 

7.2.1 0.1 Extended FLUTE FDT Schema 

The below XML Schema shall be use for the FDT Instance. 

The XML schema described in clause 7.2.10.3 is within this schema reference using the relative URI "ietf-flute- 
fdt.xsd". 

<?xml version="l . 0" encoding="UTF-8" ?> 
<xs : schema 

xmlns="urn : IETF : metadata : 2 005 : FLUTE : FDT" 
xmlns : f l="urn : IETF rmetadata : 2005 : FLUTE : FDT" 
xmlns :xs="http : //www. w3 . org/2 00 l/XMLSchema" 
xmlns :mbms="urn:3GPP rmetadata: 2 005 :MBMS : FLUTE: FDT" 
targetNamespace= "urn : IETF : metadata : 2 005 : FLUTE : FDT" 
elementFormDefault= "qualified" > 

<xs : import namespace= "urn : 3GPP : metadata : 2 005 :MBMS : FLUTE : FDT"/ > 
<xs : redefine schemaLocation=" ietf -f lute-f dt .xsd" > 
<xs : complexType name="FileType" > 
<xs : complexContent> 

<xs : extension base="f 1 : FileType"> 
<xs : sequence> 

<xs:element name="Group" type="mbms :groupIdType" minOccurs="0" 

maxOccurs= " unbounded" / > 
<xs : element name="MBMS-Session- Identity" 

type="mbms : MEMS -Session- Identity- Type" minOccurs=" 0" 
maxOccurs= " unbounded" / > 
</xs : sequence> 
</xs : extension> 
</xs : complexContent> 
</xs : complexType > 

<xs : complexType name= " FDT- InstanceType " > 
<xs : complexContent> 

<xs : extension base="f 1 : FDT- InstanceType " > 
<xs : sequence> 

<xs:element name="Group" type="mbms :groupIdType" minOccurs=" 0" 

maxOccurs= " unbounded" / > 
<xs : element name="MBMS-Session- Identity-Expiry" 

type="mbms :MBMS- Session- Identity- Expiry- Type" minOccurs="0" 
maxOccurs= "unbounded" /> 
</xs : sequence> 
</xs : extension> 
</xs : complexContent> 
</xs : complexType > 
</xs : redef ine> 
</xs : schema> 



7.2.1 0.2 3GPP FDT Extension Type Schema 

The extension of the IETF FLUTE FDT schema is done using the following schema definition: 

<?xml version="l . 0" encoding="UTF-8" ?> 
<xs : schema 

xmlns= "urn :3GPP: metadata: 2 005: MEMS: FLUTE: FDT" 
xmlns :xs="http : //www. w3 . org/2 OOl/XMLSchema" 
targetNamespace="urn: 3GPP : metadata : 2 005 :MBMS : FLUTE: FDT" 
elementFormDefault= "qualified" > 

<xs : complexType name="MBMS-Session-Identity-Expiry-Type" > 
<xs : simpleContent> 

<xs : extension base="MBMS-Session-Identity-Type" > 

<xs : attribute name="value" type="xs :unsignedlnt " use="required"/> 
</xs : extension> 
</xs : simpleContent> 
</xs : complexType > 
<xs : simpleType name="MBMS-Session-Identity-Type" > 

<xs : restriction base="xs :unsignedByte"/> 
</xs : simpleType > 
<xs : simpleType name="groupIdType" > 

<xs : restriction base="xs : string" ></xs : restriction> 
</xs : simpleType > 
</xs : schema> 
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7.2.10.3 IETF FDT Schema 

Below is the XML schema that has been used to vaHdate the above XML schema extension. 

Note: As the schema in RFC 3926 is not vaHd there exist no stable reference, thus this specification will include this 
schema until IETF has published an updated version of the schema. 

<?xml version="l . 0" encoding="UTF-8" ?> 
<xs : schema 

xmlns= "urn : IETF : metadata : 2 005 : FLUTE : FDT" 
xmlns :xs="http : //www. w3 . org/2 00 l/XMLSchema" 
targetNamespace= " urn : IETF : metadata : 2 5 : FLUTE : FDT " 
elementFormDefault= "qualified" > 

<xs: element name=" FDT- Instance" type="FDT-InstanceType"/> 
<xs : complexType name= " FDT- InstanceType " > 
<xs : sequence> 

<xs: element name="File" type="FileType" maxOccurs= "unbounded" /> 

<xs:any namespace="##other" processContents="skip" minOccurs="0" maxOccurs= "unbounded" /> 
</xs : sequence> 

<xs : attribute name=" Expires" type="xs : string" use="required"/> 
<xs : attribute name=" Complete" type="xs : boolean" use="optional"/> 
<xs : attribute name=" Content -Type" type="xs : string" use="optional"/> 
<xs : attribute name=" Content -Encoding" type="xs : string" use="optional"/> 
<xs : attribute name="FEC-OTI-FEC-Encoding-ID" type="xs runsignedLong" use="optional"/> 
<xs : attribute name="FEC-OTI-FEC- Instance- ID" type="xs runsignedLong" use= "optional "/> 
<xs : attribute name="FEC-OTI -Maximum-Source-Block-Length" type="xs runsignedLong" 

use= " optional " / > 
<xs : attribute name="FEC-OTI-Encoding-Symbol-Length" type="xs runsignedLong" use="optional"/> 
<xs r attribute name="FEC-OTI-Max-Number-of -Encoding-Symbols" type="xs runsignedLong" 

use= " optional " / > 
<xs r attribute name="FEC-OTI-Scheme-Specif ic-Inf o" type="xs rbase64Binary" use="optional"/> 
<xs r anyAttribute processContents="skip"/> 
</xs r complexType > 
<xs r complexType name="FileType" > 
<xs r sequence> 

<xsrany namespace="##other" processContents="skip" minOccurs="0" maxOccurs= "unbounded" /> 
</xs r sequence> 

<xs r attribute name= "Content-Location" type="xs r anyURI" use="required"/> 
<xs r attribute name="TOI" type="xs rpositivelnteger" use=" required" /> 
<xs r attribute name=" Content -Length" type="xs runsignedLong" use="optional"/> 
<xs r attribute name= "Transfer-Length" type="xs runsignedLong" use= "optional "/> 
<xs r attribute name=" Content -Type" type="xs r string" use= "optional "/> 
<xs r attribute name=" Content -Encoding" type="xs r string" use= "optional "/> 
<xs r attribute name=" Content -MD5" type="xs rbase64Binary" use= "optional "/> 
<xs r attribute name="FEC-OTI-FEC-Encoding-ID" type="xs runsignedLong" use="optional"/> 
<xs r attribute name="FEC-OTI-FEC-Instance-ID" type="xs runsignedLong" use="optional"/> 
<xs r attribute name="FEC-OTI -Maximum-Source-Block-Length" type="xs runsignedLong" 

use= " optional " / > 
<xs r attribute name="FEC-OTI-Encoding-Symbol-Length" type="xs runsignedLong" use="optional"/> 
<xs r attribute name="FEC-OTI-Max-Number-of -Encoding-Symbols" type="xs runsignedLong" 

use= " optional " / > 
<xs r attribute name="FEC-OTI-Scheme-Specif ic-Inf o" type="xs rbase64Binary" use="optional"/> 
<xs r anyAttribute processContents="skip"/> 
</xs r complexType > 
</xs r schema> 



7.2.10.4 Example Of FDT 



<?xml version="l . 0" encoding="UTF-8" ?> 
<FDT-Instance 

xmlns="urnr IETF r metadata r 2 005 r FLUTE r FDT" 

xmlns rxsi="http r //www. w3 . org/2001/XMLSchema-instance" 

xsi r schemaLocation="urnr IETF rmetadata r 2005 r FLUTE r FDT 3gpp-f lute-f dt-choice3 .xsd" 

FEC-OTI -FEC-Encoding- ID= " 1 " 

Complete= " true " 

Content - Encoding= " gz ip " 

FEC-OTI -Encoding- Symbol -Length=" 5 12" 

Expires="331129600"> 

<File 

Content-Type="application/sdp" 
Content-Length="7543" 
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Transfer-Length="42 94" 

T0I="2" 

FEC-OTI -Encoding-Symbol -Length= " 16 " 

FEC -OTI - Scheme - Spec ific-lnfo="AAEBBA==" 

Content-Location="http : //www. example . com/fancy-session/main. sdp" > 

<MBMS- Session- Identity>93</MBMS- Session- Identity> 
</File> 
<File 

Content -Type= " String" 

Content-Length=" 161934" 

Transf er-Length= "15 7821" 

T0I="3" 

FEC - OTI -Encoding- Symbol -Length=" 5 12" 

Content-Location="http: //www. example . com/fancy-session/trailer. 3gp"> 

<MBMS- Session- Identity>93</MBMS- Session- Identity> 
</File> 

<MBMS- Session- Identity- Expiry value="33112 8876 0" >93</MBMS-Session-Identity-Expiry> 
</FDT-Instance> 



7.2.1 1 MBMS Session Identify 



The MBMS-Session-Identity element associates the file to the identity of the MBMS session. If the file will be part of 
several MBMS transmission sessions, then a list of MBMS session identities is defined. 

The MBMS -Session-Identity -Expiry element associates an expiration time with a MBMS session identity value. Similar 
to the FLUTE FDT expiration time, the MBMS session identity expiration time (value attribute) is expressed within the 
FDT Instance payload as a 32 bit data field. The value of the data field represents the 32 most significant bits of a 64 
bit Network Time Protocol (NTP) [78] time value. These 32 bits provide an unsigned integer representing the time in 
seconds relative to hours 1 January 1900. 

7.2.12 FEC Scheme definition 

7.2.12.1 General 

This clause defines an FEC encoding scheme for the MBMS forward error correction code defined in Annex B for the 
download delivery method. This scheme is identified by FEC Encoding ID 1 . The FEC Payload ID format and FEC 
Object Transmission Information format are as defined in the following clauses. 

7.2.12.2 FEC payload ID 

The FEC Payload ID shall be a 4 octet field defined as follows: 



Source Block Number (SBN) 


Encoding Symbol ID (ESI) 



Source Block Number (SBN), (16 bits): An integer identifier for the source block that the encoding symbols within the 
packet relate to. 

Encoding Symbol ID (ESI), (16 bits): An integer identifier for the encoding symbols within the packet. 

The interpretation of the Source Block Number and Encoding Symbol Identifier is defined in Annex B. 

7.2.12.3 FEC Object Transmission Information 

The FEC Object Transmission information shall consist of: 
The FEC Encoding ID 
The Transfer Length (F) 
The parameters T, Z, N and A defined in Annex B. 
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When EXT-FTI is used to communicate the Object Transmission Information, the FEC Encoding ID and Transfer 
Length shall be coded according to FLUTE [9] . The other parameters shall be encoded in the FEC Encoding ID specific 
portion of the EXT_FTI field as shown in Figure 10a below. 



General EXT_FTI format 


Encoding Symbol Length (7) 


Number of Source Blocks (Z) 


Number of Sub-Blocks 

(AO 


Symbol Alignment 
Parameter (A) 



Figure 10a: FEC Encoding ID-specific EXT_FTI format 

The parameters T and Z are 16 bit unsigned integers, N and A are 8 bit unsigned integers. 

When the FDT is used to deliver the FEC Object Transmission Information, then the FEC Encoding ID, Transfer 
Length (F) and Encoding Symbol Length (7) shall be encoded using the Transfer-Length, FEC-OTI-Encoding-ID and 
FEC-OTI-Encoding-Symbol-Length elements defined in sub-clause 7.2.10. The remaining parameters Z, A^, A, shall be 
encoded as a 4 byte field within the FEC-OTI-Scheme-Specific-Info field, according to the format specified in Figure 
10a above, excepting the Encoding Symbol Length field. 

7.3 SDP for Download Delivery Method 

7.3.1 Introduction 

RFC 3926 [9] describes required and optional parameters for FLUTE session and media descriptors. This clause 
specifies SDP for FLUTE session that is used for the MBMS download and service announcement sessions. The formal 
specification of the parameters is given in ABNF (RFC 4234 [23]). 

7.3.2 SDP Parameters for MBMS download session 

The semantics of a Session Description of an MBMS download session includes the following parameters: 

The sender IP address. 

The number of channels in the session. 

The destination IP address and port number for each channel in the session per media. 

The Transport Session Identifier (TSI) of the session. 

The start time and end time of the session. 

The protocol ID (i.e. FLUTE/UDP). 

Media type(s) and fmt-list. 

Data rate using existing SDP bandwidth modifiers. 

Mode of MBMS bearer per media. 

FEC capabilities and related parameters. 

Service-language(s) per media. 

This list includes the parameters required by FLUTE - RFC 3926 [9] 

These shall be expressed in SDP (RFC 2327 [14], draft-ietf-mmusic-sdp-srcfilter [15], RFC 3266 [16]) syntax 
according to the following clauses. 
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7.3.2.1 Sender IP address 

There shall be exactly one IP sender address per MBMS download session, and thus there shall be exactly one IP source 
address per complete MBMS download session SDP description. The IP source address shall be defined according to 
the source-filter attribute ("a=source-filter:") (RFC 2327 [14] and draft-ietf-mmusic-sdp-srcfilter [15]) for both IPv4 and 
IPv6 sources, with the following exceptions: 

1 . Exactly one source address may be specified by this attribute such that exclusive-mode shall not be used and 
inclusive-mode shall use exactly one source address in the <src-list>. 

2. There shall be exactly one source-filter attribute per complete MBMS download session SDP description, and 
this shall be in the session part of the session description (i.e. not per media). 

3. The * value shall be used for the <dest-address> subfield, even when the MBMS download session employs only 
a single LCT (multicast) channel. 

7.3.2.2 Number of channels 

Only one FLUTE channel is allowed per FLUTE session in the present document and thus there is no further need for a 
descriptor of the number of channels. 

7.3.2.3 Destination IP address and port number for channels 

The FLUTE channel shall be described by the media-level channel descriptor. These channel parameters shall be per 
channel: 

• IP destination address. 

• Destination port number. 

The IP destination address shall be defined according to the "connection data" field ("c=") of SDP (RFC 2327 [14] and 
draft-ietf-mmusic-sdp-srcfilter [15]). The destination port number shall be defined according to the <port> sub-field of 
the media announcement field ("m=") of SDP (RFC 2327 [14] and draft-ietf-mmusic-sdp-srcfilter [15]). 

The presence of a FLUTE session on a certain channel shall be indicated by using the "m-line" in the SDP description 
as shown in the following example: 

m=application 12345 FLUTE/UDP 

c=IN IP6 FF1E:03AD::7F2E:172A:1E24/1 

In the above SDP attributes, the m-line indicates the media used and the c-line indicates the corresponding channel. 
Thus, in the above example, the m-line indicates that the media is transported on a channel that uses FLUTE over UDP. 
Further, the c-line indicates the channel address, which, in this case, is an IPv6 address. 

7.3.2.4 Transport Session Identifier (TSI) of the session 

The combination of the TSI and the IP source address identifies the FLUTE session. Each TSI shall uniquely identify a 
FLUTE session for a given IP source address during the time that the session is active, and also for a large time before 
and after the active session time (this is also an LCT requirement - RFC 3451 [11]). 

The TSI shall be defined according the SDP descriptor given below. There shall be exactly one occurrence of this 
descriptor in a complete FLUTE SDP session description and it shall appear at session level. 

The syntax in ABNF is given below: 

flute-tsi-line = "a=flute-tsi:" tsi CRLF 

tsi=l*15DIGIT 
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7.3.2.5 Multiple objects transport indication 

RFC 3626 [9] requires the use of the Transport Object Identifier (TOI) header field (with one exception for packets with 
no payload when the A flag is used). The transport of a single FLUTE file requires that multiple TOIs are used (TOI 
for FDT Instances). Thus, there is no further need to indicate to receivers that the session carries packets for more than 
one object and no SDP attribute (or other FLUTE out of band information) is needed for this. 

7.3.2.6 Session Tinning Parameters 

A MBMS download session start and end times shall be defined according to the SDP timing field ("t=") 
(RFC 2327 [14] and draft-ietf-mmusic-sdp-srcfilter [15]). 

7.3.2.7 Mode of MBMS bearer per media 

A new MBMS bearer mode declaration attribute is defined which results in, e.g.: 

• a=mbms-mode:broadcast 1234 1 

The MBMS bearer mode declaration attribute shall be used in session descriptions using one or more MBMS broadcast 
mode media. If all media declarations use MBMS broadcast mode, then the SDP attribute may be declared at session 
level. In that case the session level attribute applies to all media without a media level occurance of the "mbms-mode" 
attribute. If one or more media using MBMS multicast mode is present in the same declaration as media using MBMS 
broadcast mode, then only media using the MBMS broadcast mode will contain the "mbms-mode" attribute. 

mbms-bearer-mode-declaration-line = "a=mbms-mode:" "broadcast" SP tmgi SP mbms-counting-information 
CRLF 

tmgi=l*15DIGIT 

mbms-counting-indication = 1 * DIGIT 

The Temporary Mobile Group Identity (tmgi) information element is defined in TS 24.008 [40]. Octets 3 to 8 are 
always encoded in tmgi attribute as a decimal number. Octet 3 is the most significant octet. 

The MBMS Counting Information (mbms-counting-information) information element is defined in TS 25.413 [87] and 
indicates whether the RAN level counting procedures are applicable or not for the MBMS broadcast mode. The value 
corresponds to the information element value of 'not counting' and the value 1 corresponds to the information element 
value 'counting'. 

7.3.2.8 FEC capabilities and related parameters 

A new EEC-declaration attribute is defined which results in, e.g.: 

• a=FEC-declaration:0 encoding-id=l 

This attribute may be used on both session-level and media-level. Multiple instances are allowed to specify several 
different FEC declarations. The attribute is used on session level to define FEC declarations used by multiple media 
components. Each media component references an FEC declaration using the 'a=FEC' attribute. On media level it is 
used to define FEC declarations which are only valid for a single media component. If FEC declarations on both session 
and media level use the same reference number (fec-ref) then the media level declaration takes precedence for that 
media component. 

This attribute is optional to use for the download delivery method as the information will be available elsewhere (e.g. 
FLUTE FDT Instances). If this attribute is not used, and no other FEC-OTI information is signalled to the UE by other 
means, the UE may assume that support for FEC id is sufficient capability to enter the session. 

A new FEC-declaration reference attribute is defined which results in, e.g.: 

• a=FEC:0 

This is a media-level only attribute, used as a short hand to reference one of one or more FEC-declarations. 
The syntax for the attributes in ABNF - RFC 4234 [23] is: 
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fec-declaration-line = "a=FEC-declaration:" fec-ref SP fec-enc-id [";" SP fec-inst-id] CRLF 

fec-ref = 1 *3DIGIT ; value is the SDP-internal identifier for FEC-declaration. 

fec-enc-id = "encoding-id=" enc-id 

enc-id = 1 *DIGIT ; value is the FEC encoding ID used 

fec-inst-id = "instance-id=" inst-id 

inst-id = 1 *DIGIT ; value is the FEC Instance ID used. 

fee-line = "a=FEC:" fec-ref CRLF 

7.3.2.9 Service-language(s) per media 

The existing SDP attribute "a=lang" is used to label the language of any language-specific media. The values are taken 
from RFC 3066 [73] which in turn takes language and (optionally) country tags from ISO 639 [74] and ISO 3166 [75] 
(e.g. "a=lang:EN-US"). These are the same tags used in the User Service Description XML. 

7.3.2.10 Bandwidth Specification 

The maximum bit-rate required by this FLUTE session shall be specified using the "AS" bandwidth modifier 
RFC 2327 [14] on media level. The Application Specific (AS) bandwidth for a FLUTE session shall be the largest sum 
of the sizes of all packets transmitted during any one second long period of the session, expressed as kilobits. The size 
of the packet shall be the complete packet, i.e. IP, UDP and FLUTE headers, and the data payload. 

7.3.3 SDP Examples for FLUTE Session 

Here is a full example of SDP description describing a FLUTE session: 

v=0 

o=userl23 2890844526 2890842807 IN IPS 2201 : 056D : : 112E : 144A: 1E24 

s=File delivery session example 

i=More information 

t=2873397496 2873404696 

a=mbms-mode: broadcast 1234 1 

a=FEC- declarat ion : encoding- id=l 

a=source- filter: incl IN IP6 * 2001 : 210 : 1 : 2 : 240 : 96FF: FE25 : 8EC9 

a=flute-tsi : 3 

m=application 12345 FLUTE /UDP 

C=IN IP6 FFIE: 03AD : : 7F2E : 1 72A : 1E24/1 

b=64 

a=lang:EN 

a=FEC:0 



8 Streaming delivery method 

8.1 Introduction 



The purpose of the MBMS streaming delivery method is to deliver continuous multimedia data (i.e. speech, audio and 
video) over an MBMS bearer. This delivery method complements the download delivery method which consists of the 
delivery of files. The streaming delivery method is particularly useful for multicast and broadcast of scheduled 
streaming content. 



8.2 Transport protocol 



RTP is the transport protocol for MBMS streaming delivery. RTP provides means for sending real-time or streaming 
data over UDP and is already used for the transport of PSS in 3GPP. RTP provides RTCP for feedback about the 
transmission quality. The transmission of RTCP packets in the downlink (sender reports) is allowed. In this version of 
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the specification, RTCP RR shall be turned off by SDP RR bandwidth modifiers. Note that in the context of MBMS 
detection of link aliveness is not necessary. 

8.2.1 RTP payload formats for media 

The RTP payload formats and corresponding MIME types are aligned with those defined in PSS Rel-6 3GPP TS 26.234 
[47] as much as possible. For RTP/UDP/IP transport of continuous media the following RTP payload formats shall be 
used: 

• AMR narrow-band speech codec (see sub-clause 10.2) RTP payload format according to RFC 4867 [33]. A 
MBMS client is not required to support multi-channel sessions. 

• AMR wideband speech codec (see sub-clause 10.2) RTP payload format according to RFC 4867 [33]. A MBMS 
client is not required to support multi-channel sessions. 

• Extended AMR-WB codec (see sub-clause 10.3) RTP payload format according to [34]. 

• Enhanced aacPlus codec (see sub-clause 10.3): RTP payload format and MIME types according to RFC 3640 
[41], namely the Low Bit-Rate AAC or the High Bit-Rate AAC modes. 

• H.264 (AVC) video codec (see sub-clause 10.5) RTP payload format according to RFC 3984 [35]. An MBMS 
client supporting H.264 (AVC) is required to support all three paclcetization modes: single NAL unit mode, non- 
interleaved mode and interleaved mode. For the interleaved paclcetization mode, an MBMS client shall support 
streams for which the value of the "sprop-deint-buf-req" MIME parameter is less than or equal to MaxCPB * 
1000 / 8, inclusive, in which "MaxCPB" is the value for VCL parameters of the H.264 (AVC) profile and level 
in use, as specified in [TBD]. 

8.2.2 FEC mechanism for RTP 

The 'MBMS FEC scheme' is described in sub-clause 8.2.2.8. 

A UE that supports MBMS User Services shall support a decoder for the 'MBMS FEC scheme'. The use of MBMS FEC 
by the sender is recommended, but it is permitted not to use it. In the case where the FEC is not used by the sender, the 
FEC Layer should not be used (i.e. RTP is mapped onto UDP directly). 

This sub-clause defines a generic mechanism for applying Forward Error Correction to streaming media. The 
mechanism consists of three components: 

(i) construction of an FEC source block from the source media packets belonging to one or several UDP packet 
flows related to a particular segment of the stream(s) (in time). The UDP flows include RTP, RTCP, SRTP and 
MIKEY packets. 

(ii) modification of source packets to indicate the position of the source data from the source packet within the 
source block 

(iii)definition of repair packets, sent over UDP, which can be used by the FEC decoder to reconstruct missing 
portions of the source block. 

The mechanism does not place any restrictions on the source data which can be protected together, except that the 
source data is carried over UDP. The data may be from several different UDP flows that are protected jointly. 

A receiver supporting the streaming delivery method shall support the packet format for FEC source packets and may 
also support the packet format for FEC repair packets. 

At the sender, the mechanism begins by processing original UDP packets to create: 

(i) a stored copy of the original packets in the form of a source block; and 

(ii) FEC source packets for transmission to the receiver. 

After constructing the source block from the original UDP payloads to be protected and their flow identity (based on 
destination IP address and UDP port), the FEC encoder generates the desired amount of FEC protection data, i.e. 
encoding symbols. These repair symbols are then sent using the FEC repair packet format to the receiver. The FEC 
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repair packets are sent to a UDP destination port different from any of the original UDP packets' destination port(s) as 
indicated by the signaHng. 

The receiver recovers the original packets directly from the FEC source packets and buffers them at least the min- 
buffer-time to allow time for the FEC repair. The receiver uses the FEC source packets to construct a (potentially 
incomplete) copy of the source block, using the Source FEC Payload ID in each packet to determine where in the source 
block the packet shall be placed. In indication of the UDP flow (i.e. destination IP address and UDP port) the packet is 
part of is included in the source block with the UDP payload. 

If any FEC source packets have been lost, but sufficient FEC source and FEC repair packets have been received, FEC 
decoding can be performed to recover the FEC source block. The original packets UDP payload and UDP flow identity 
can then be extracted from the source block and provided to the upper layer. If not enough FEC source and repair 
packets were received, only the original packets that were received as FEC source packets will be available. The rest of 
the original packets are lost. 

If a UE that supports MBMS User Services receives a mathematically sufficient set of encoding symbols generated 
according to the encoder specification in Annex B for reconstruction of a source block then the decoder shall recover 
the entire source block. Note that the example decoder described in Annex E fulfils this requirement. 

Note that the receiver must be able to buffer all the original packets and allow time for the FEC repair packets to arrive 
and FEC decoding to be performed before media playout begins. The min-buffer-time parameter specified in sub-clause 
8.3.1.8 helps the receiver to determine a sufficient duration for initial start-up delay. 

The Source and Repair FEC payload IDs are used to associate the FEC source packets and FEC repair packets, 
respectively, to a source block. The Source and Repair FEC payload ID formats are part of the definition of the FEC 
scheme. Each FEC scheme is identified by an FEC Encoding ID and, in the case of underspecified FEC schemes, FEC 
Instance ID, values. One FEC scheme for the streaming delivery method is specified in sub-clause 8.2.2.8. Any FEC 
schemes using the packet formats defined in the present document shall be systematic FEC codes and may use different 
FEC payload ID formats for FEC source packets and FEC repair packets. 

The protocol architecture is illustrated in figure 1 1 . 
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Figure 1 1 : FEC mechanism for the streaming delivery method interaction diagram 
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Figure 1 1 depicts how one or more out of several possible packet flows of different types (Audio, video, text RTP and 
RTCP flows, MIKEY flow) are sent to the FEC layer for protection. The source packets are modified to carry the EEC 
payload ID and a new flow with repair data is generated. The receiver takes the source and repair packets and buffers 
them to perform, if necessary, the EEC decoding. After appropriate buffering received and recovered source packets are 
forwarded to the higher layers. The arrows in the figure indicate distinct data flows. 

8.2.2.1 Sending Terminal Operation (Informative) 

It is assumed that the sender has constructed or received original data packets for the session. These may be RTP, 
RTCP, MIKEY or other UDP packets. The following procedures are based on the UDP payload and the identity of the 
UDP flow. 

In order to EEC protect a sequence of original data packets, the sender constructs a source block as specified in sub- 
clause 8.2.2.6 to which the EEC algorithm is to be applied, and includes the original source packet data within EEC 
source packets. The following operations describe a possible way to generate compliant EEC source packet and EEC 
repair packet streams: 

1. Each original packet is placed in the source block. In doing so, the Source EEC Payload ID information to be 
included in the EEC payload ID of the EEC source packet can be determined. In the source block the identity of 
the packef's flow is marked using the Elow ID. See sub-clauses 8.2.2.6 and 8.2.2.7 for details. 

2. The EEC source packet is constructed according to sub-clause 8.2.2.4. The identity of the original flow is 
maintained by the source packet through the use of the destination UDP port number and destination IP address, 
which has been advertised (for example using SDP), as carrying EEC source packets generated from an original 
stream of a particular protocol (e.g. RTP, RTCP, SRTP, MIKEY etc.). See sub-clause 8.2.2.13. 

3. The EEC source packet generated is sent according to UDP procedures defined in REC 4867 [33]. 

When a source block is complete, the EEC encoder generates encoding symbols and places these symbols into EEC 
repair packets, to be conveyed to the receivers. These repair packets are sent using normal UDP procedures to a unique 
destination port to separate it from any of the source packet flows. 

In particular cases it may be advantageous not to use EEC for some source blocks and to signal this to the receiver. In 
this case the sender may send one or more empty repair packets consisting exclusively on the Repair EEC Payload ID. 
This will be helpful in particular for selective EEC where some of the source blocks (e.g. consisting of reference video 
frames) are EEC protected while others (e.g. consisting exclusively of non-reference frames) will not be protected. 

8.2.2.2 Receiving Terminal Operation (Informative) 

The following describes a possible receiver algorithm, when receiving an EEC source or repair packet: 

1 . If a EEC source packet is received (as indicated by the UDP port on which was received): 

a. The original source packet is reconstructed by removing the Source EEC Payload ID. The resulting packet is 
buffered to allow time for the EEC repair. 

b. The resulting packet is placed into the source block according to the information in the Source EEC Payload 
ID and the source block format described in sub-clause 8.2.2.6. The UDP port the packet was received on is 
used to determine the Elow ID written into the source block. 

2. If an EEC repair packet is received (as indicated by the UDP port), the contained encoding symbols are placed 
into an EEC encoding block according to the Repair EEC Payload ID. In case the received EEC repair packet is 
empty, there are no repair symbols to be placed in the EEC encoding block. 

3. If at least one source packet is missing, then EEC decoding may be desirable. The EEC decoder determines if 
the encoding block constructed in steps 1 and 2 contains enough symbols from the source and repair packets for 
decoding and, if so, performs the decoding operation. If only empty EEC repair packets are received, the receiver 
may start immediately some procedures to conceal the effect of missing media data. 

4. Any missing source packets that were reconstructed during the decoding operation are then buffered as normal 
received packets (see step la above). 
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Note that the above procedure may result in that not all original packets are recovered, and they must simply be marked 
as being lost. 

Obviously, buffering and packet re-ordering arerequired to insert any reconstructed packets in the appropriate place in 
the packet sequence if that is necessary according to the used higher layer protocol (RTP, RTCP or MIKEY). To allow 
receivers to determine the minimal start-up buffering requirement for FEC decoding, the min-buffer-time parameter 
indicates a minimum initial buffering time that is sufficient regardless of the position of the stream in which the 
reception starts. 



8.2.2.3 



(Void) 



8.2.2.4 



Packet format for FEC source packets 



The packet format for FEC source packets shall be used to encapsulate an original UDP packet.. As depicted in figure 
12, it consists of the original UDP packet, followed by the Source FEC payload ID. 



IP Header 



UDP Header 



Original UDP Payload 



Source FEC Payload ID 



Figure 12: Structure of the FEC packet format for FEC source packets 

The destination IP address and UDP port shall be set as indicated in the session control signalling. This ensures that the 
receiver can determine which protocols and FEC Payload ID formats are used for this flow. The remaining fields in the 
IP and UDP headers shall be set according to their specifications. 

The UDP payload shall consist of the original UDP Payload followed by the Source FEC Payload ID. 

The Source FEC Payload ID consists of information required for the operation of the FEC algorithm. Its construction is 
specified in sub-clause 8.2.2.9. 

The FEC Source packets over IP and UDP are indicated to be used for a flow by using one of the SDP protocol 
identifiers 'UDP/MBMS-FEC/RTP/AVP', 'UDP/MBMS-FEC/RTP/SAVP' depending on the upper layer protocol 
RTP/AVP or RTP/SAVP respectively. If MIKEY is FEC protected and encapsulated in source packets, then it is 
indicated in the security description using the fecProtection element and the destination IP address. 



8.2.2.5 



Packet Format for Repair packets 



The packet format for FEC repair packets carries, as its payload, encoding symbols generated by the FEC encoding 
process. The format of a FEC repair packet is depicted in figure 13. The UDP payload consists of the Repair FEC 
Payload ID, and zero, one or more repair symbols. The format of the Repair FEC payload ID is defined in clause 
8.2.2.10. 



IP Header 
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UDP Header 



Repair FEC Payload ID 



Repair symbol(s) 



Figure 13: Payload structure for FEC repair packets 

The repair packet sent over IP and UDP is indicated in the SDP using the protocol identifier 'UDP/MB MS -REPAIR'. 

8.2.2.6 Structure of the FEC source block 

This clause defines the layout of the FEC source block. 

The FEC source block shall contain at least one complete UDP packet payload (i.e. excluding the IP and UDP headers), 
and three octets indicating the UDP flow from which the packet was taken and the length of the UDP packet. Note: this 
implies that no source UDP packet be larger than the length of the FEC source block minus 3. 

Let 

n be the number of UDP packets in the source block, n is determined dynamically during the source block 
construction process. 

Ri denote the octets of the UDP payload of the /th UDP packet to be added to the source block. 

li be the length of R^ in octets. 

Li denote two octets representing the value of li in network byte order (high order octet first). 

fi denote an integer 'flow ID' identifying the UDP flow from which the i* packet was taken 

Fi denote a single octet representing the value of/ 

Si be the smallest integer such that SiT >= (li-\-3). 

Pi denote SiT-( /^+3) zero octets. Note: Pi are padding octets to align the start of each UDP packet with the start of a 
symbol. 

T be the source symbol size in bytes. 

Then, the source block is constructed by concatenating Fi ,Li, Ri, Pi for i = 1,2, ... n. and the source block size, S = sum 
{SiT, i=l, ...,n}. 

A UDP flow is uniquely defined by an IP source and destination address and UDP source and destination port value. 
The assignment of Flow ID values to UDP flows is described in sub-clauses 8.2.2.13 and 8.3.1.9. 



8.2.2.7 



FEC block Construction algorithm and example (informative) 



When the original UDP packet is placed into the source block, the value of the UDP flow identifier,F, followed by the 
value of the UDP payload length, L, are first written as a single byte and two-byte value in network byte order (i.e. with 
high order byte first) respectively into the first available bytes in the source block, followed by the UDP packet payload 
itself (i.e.not including the IP/UDP headers). Following this, if the next available byte is not the first byte of a new 
symbol, then padding bytes up to the next symbol boundary shall be included using the value in each byte. As long as 
any source UDP packets remain to be placed, the procedure is repeated starting each UDP flow identifier at the start of 
the next encoding symbol. 

An example of forming a source block is given in figure 14 below. In this example, three UDP packets of lengths 26, 52 
and 103 bytes have been placed into a source block with symbol size T = 16 bytes. The first two packets are from UDP 
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flow and the third from UDP flow 1. Each entry in Figure 14 is a byte and the rows correspond to the source symbols 
and are numbered from to 12. Bij denotes the (j+l)th byte of the (i+l)th UDP packet. 
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Figure 14: Source block consisting of 3 source UDP packets of lengths 26, 52 and 103 bytes. 



8.2.2.8 



MBMS FEC scheme definition 



This clause defines a FEC encoding scheme for MBMS forward error correction as defined in Annex B for the 
streaming dehvery method. This scheme is identified by the FEC encoding ID 1 . It utihzes the method for forming FEC 
source block as defined in sub-clause 8.2.2.6. It defines two different FEC Payload ID formats, one for FEC source 
packets and another for FEC repair packets. 

8.2.2.9 Source FEC Payload ID 

The Source FEC payload ID is composed as follows: 



Source Block Number (SBN) 



Encoding Symbol ID (ESI) 



Source Block Number (SBN), (16 bits): An integer identifier for the source block that the source data within the 

packet relates to. 
Encoding Symbol ID (ESI), (16 bits): The starting symbol index of the source packet in the source block. 

Figure 15: Source FEC Payload ID 

The interpretation of the Source Block Number and Encoding Symbol Identifier is defined in Annex B. 
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8.2.2.10 Repair FEC payload ID 

The structure of the Repair FEC Payload ID is as follows: 



Source Block Number (SBN) 



Encoding Symbol ID (ESI) 



Source Block Length (SBL) 



Source Block Number (SBN), (16 bits): An integer identifier for the source block that the repair symbols within the 

packet relate to. 

Encoding Symbol ID (ESI), (16 bits): integer identifier for the encoding symbols within the packet. 

Source Block Length (SBL), (16 bits): The number of source symbols in the source block. 

The interpretation of the Source Block Number, Encoding Symbol Identifier and Source Block Length is defined in 

Annex B. 

Figure 16: Repair FEC Payload ID 

In case of empty Repair FEC packets, the actual value of ESI is irrelevant and it may take any value between 0X0000 
and OXFFFF. 



8.2.2.10a FEC Object Transmission information 

The FEC Object Transmission information shall consist of: 

the maximum source block length, in symbols 

the symbol size, in bytes 

The symbol size and maximum source block length shall be encoded into a 4 octet field (Network Byte Order) defined 
as follows: 



Symbol Size (T) 


Maximum Source Block Length 



Symbol Size (7) (16 bits): The size of an encoding symbol, in bytes. 

Maximum Source Block Length (16 bits): The maximum length of a source block, in symbols. 

The interpretation of Tis defined in Annex B. 

The Source Block Length signalled within the Repair FEC Payload ID of any packet of a stream shall not exceed the 
Maximum Source Block Length signalled within the FEC Object Transmission Information for the stream. 

The FEC Object Transmission Information shall be communicated as described in sub-clause 8.2.2.14. Note, the FEC 
Object Transmission Information is only communicated in SDP. 

8.2.2.1 1 Hypothetical FEC Decoder 

This clause specifies the hypothetical FEC decoder and its use to check packet stream and MBMS receiver 
conformance. 

The hypothetical FEC decoder uses the packet stream, the transmission time of each packet, the initial buffering delay, 
and the SDP for the stream as inputs. The packet stream from the beginning of the FEC source block until the end of the 
stream shall comply with the hypothetical reference decoder as specified below when the initial buffer delay equals to 
the value of the min-buffer-time parameter. 

The maximum buffer size for MBMS streaming is 1 Mbytes. The default hypothetical FEC decoding buffer size is 
equal to 1 Mbytes. 
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For the packet stream, the buffer occupancy level of the hypothetical FEC decoding buffer shall not exceed the value of 
the buf-size parameter, when it is present in the SDP, or the default FEC decoding buffer size, when the buf-size 
parameter is not present in the SDP. The output of the hypothetical FEC decoder shall comply with the RTF payload 
and decoding specifications of the media format. 

The hypothetical FEC decoder operates as follows: 

1) The hypothetical FEC decoding buffer is initially empty. 

2) Each FEC source packet and FEC repair packet, starting from the first packet in transmission order, is inserted to 
a FEC source block at its transmission time. The FEC source block generation is done as specified in sub-clause 
8.2.2.5. The FEC source block resides in the hypothetical FEC decoding buffer. 

3) When both the last FEC source packet and the last FEC repair packet of an FEC source block are transmitted, 
any elements of the FEC source block that are not original UDP packets (e.g. FEC repair packets and potential 
padding bytes) are removed from the hypothetical FEC decoding buffer. 

4) Original UDP packets are not removed from the hypothetical FEC decoding buffer before the signaled initial 
buffering delay has expired. Then, the first original UDP packet in sequence number order is output and removed 
from the hypothetical FEC decoding buffer immediately. Each succeeding original UDP packet is output and 
removed when the following conditions are true: 

i. The following time (in seconds) since the removal of the previous packet has elapsed: 

8 X (size of the previous original UDP packet including UDP/IP header in bytes) / (1 000 x (value of 
"b=AS" SDP attribute for the stream)) 

ii. All the packets in the same FEC source block as the original UDP packet have been transmitted. 

An MBMS client shall be capable of receiving a packet stream that complies with the hypothetical FEC decoder. 
Furthermore, in the case of RTP packets, when an MBMS client complies with the requirements for the media decoding 
of the packet stream, it shall be able to de-packetize and decode the packet stream and output decoded data at the 
correct rate specified by the RTP timestamps of the received packet stream. 

8.2.2.12 FEC encoding procedures 

EEC encoding shall be performed using the MBMS forward error correction code defined in Annex B. 

8.2.2.13 Signalling 

The signalling for streaming FEC consists of several components: 

• If several user services are bundled together they are indicated as a sequence of services in the User Service 
Bundle Description. See sub-clause 11.2 

• A separate SDP describing the FEC repair stream and all the flow Ids. Referenced from the User Service 
Bundle Description. See sub-clauses 11.2 and 8.2.2.14 

• SDP protocol identifiers and attributes to indicate the usage of the source packet format, how the FEC payload 
ID is configured and other FEC parameters such as minimal buffering delay, for the RTP/RTCP streams. See 
sub-clause 8.2.2.13a 

• Security description extensions to indicate usage of FEC source packet format, and the FEC parameters. See 
sub-clauses 11.3 and 8.2.2.13a. 

The user service description contains either a single service or several bundled services. All of the streaming delivery 
methods and security descriptions that are present within the hundleDescription element must be considered when 
configuring the FEC operations. This includes RTP, RTCP and MIKEY flows. A receiver intending to perform FEC 
decoding to cover for packet losses shall receive all the flows that are indicated to be sent as FEC source packets, even 
if the flows are in a service currently not played out. A receiver intending to use FEC shall also receive the FEC repair 
stream as described by the FEC Repair Stream Description. The delivery method" s session description, and the security 
description both carry the FEC source packet configuration information: FEC encoding ID, FEC instance ID, and FEC 
OTI information. The FEC repair packet stream is configured using the similar methods as for the source packets, with 
the addition of the Flow ID information and buffer delay parameter. 
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8.2.2.13a SDP for FEC source packet streams 

To indicate the presence of the FEC layer between IP/UDP and, RTP or SRTP a SDP protocol identifier is used. Instead 
of the normal RTP/AVP and RTP/SAVP protocol identifiers, UDP/MBMS-FEC/RTP/AVP" and "UDP/MBMS- 
FEC/RTP/SAVP" are defined respectively. Both these protocol identifiers shall use the FMT space rules that are used 
for RTP/AVP and RTP/SAVP respectively, i.e. payload types used in the RTP session is listed. The protocol identifiers 
are defined in Appendix CI. 

The FEC parameters, FEC encoding ID, FEC instance ID and FEC-OTI-Extension information are signalled using the 
mechanism defined in sub-clause 8.3.1.8. The 'a=FEC' SDP attribute shall be used to indicate the single definition that 
is used for each media component. 

For MIKEY messages the service protection description is used to indicate when FEC source packet shall be used, see 
sub-clause 1 1.3. The FEC parameter used is also defined in the service protection description. As all MIKEY packets 
from all user services arrive on the same port, the receiver must use the destination address to separate FEC protected 
packets from not FEC protected packets. This requires that all MIKEY packets sent to a specific destination address are 
either FEC protected or not. Note that it is not possible to mix protected and non-protected packets within a single 
stream as there is no mechanism to determine whether they are protected or not. 

8.2.2.14 SDP for FEC repair packet streams 

The repair packet stream is indicated in SDP using a media block with the protocol identifier 'UDP/MB MS -REPAIR'. 
The media type shall be 'application'. The FEC parameters, FEC encoding ID, FEC instance ID, FEC-OTI-Extension 
information and repair parameters (min-buffer-time) are signalled using the mechanisms defined in 8.3.1.9. A single 
FEC declaration shall be indicated using the 'a=FEC' attribute. 

The mapping of the FEC source block flow ID (see sub-clause 8.2.2.6) to the destination IP address and UDP port are 
done using the SDP attribute 'a=mbms-flowid' defined in sub-clause 8.3.1.9. 

8.2.2.15 Signalling example for FEC 

This sub-clause contains a complete signalling example for a MBMS multicast mode session using FEC with a Service 
description, a SDP for the streaming delivery method, a SDP for the FEC repair stream, and a security description. 

The top element is the security description that 

<?xml version="l . 0" encoding="UTF-8" ?> 
<bundleDescription 

xmlns="urn: 3GPP rmetadata : 2005 :MBMS : userServiceDescription" 

xmlns :xsi=" http : //www. w3 . org/2001/XMLSchema-instance " 

f ecDescriptionURI="http : //www. example . com/3gpp/mbms/sessionl-f ec . sdp" > 

<userServiceDescription 

serviceld="urn:3gpp: 01012 0123hotdog" > 
<deliveryMethod 

sessionDescriptionURl=" http: //www. example . com/3gpp/mbms/sessionl . sdp " 
protectionDescriptionURl="http: //www. example . com/3gpp/mbms/sec-descript "/> 
</userServiceDescription> 
</bundleDescription> 

The security description has the URI: http://www.example.com/3gpp/mbms/sec-descript 

<?xml version="l . 0" encoding="UTF-8" ?> 
<securityDescription 

xmlns="urn: 3GPP rmetadata : 2005 :MBMS : securityDescription" 
xmlns :xsi="http : //www. w3 . org/2001/XMLSchema-instance" 
conf identialityProtection="true" 
integrityProtect ion= " true " 
uiccKeyManagement = " true " 
< keyManagement 
waitTime="5" 
maxBackOf f = " 10 " > 

<serverURl>http: //register . example . com/</serverURI> 
<serverURI>http : //register2 . example . com/</serverURI> 
< /keyManagement > 
<keyld> 

<mediaFlow f lowID="FFlE : 03AD : : 7F2E : 172A: 1E24/4002 " > 
<MSK> 

<keyDomainID>aMoM</keyDomainID> 
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<]y[SKID>aMoAAA= = </MSKID> 
</iy[SK> 
</mediaFlow> 

<mediaFlow f lowID="FFlE : 03AD : : 7F2E : 172A: 1E24/4004 " srtpAuthenticationTagLength="4 " > 
<MSK> 

<keyDomainID>GM8M</keyDomainID> 
<MSKID>aMkAAA==</MSKID> 
</MSK> 
</mediaFlow> 
</keyId> 
<fecProtection 

f ecEncodingId= " 1 " / > 
</securityDescription> 

An example of how the SDP http://www.example.com/3gpp/mbms/sessionl.sdp could look for a session containing two 
media streams that are FEC protected. In this example we have assumed an audiovisual stream, using 56 kbps for video 
and 12 kbps for audio. In addition another 300 bits/second of RTCP packets from the source is used for the each of the 
sessions. Hence, the total media session bandwidth is 56+12+0.3+0.3 = 68.6 kbps. 

v=0 

o=ghost 2890844526 2890842807 IN IP4 2001 : 210 : 1 : 2 : 240 : 96FF : FE25 : 8EC9 

s=3GPP MBMS Streaming SDP Example 

i=Example of MBMS streaming SDP file 

u=http: //www. infoserver .example . com/ae6 

e=ghost@mailserver . example . com 

C=IN IP6 FF1E:03AD: :7F2E:172A:1E24 

t=3034423619 3042462419 

b=AS:62 

b=TIAS: 60500 

a=maxprate: 2 5 

a=source-filter: incl IN IP6 * 2001 : 210 : 1 : 2 : 240 : 96FF : FE25 : 8EC9 

a=FEC-declaration: encoding- id=l ; instance-id=0 

m=video 4 02 UDP/MBMS-FEC/RTP/AVP 96 

b=TIAS: 55000 

b=RR:0 

b=RS:300 

a=rtpmap:96 H263-2000/90000 

a=fmtp:96 prof ile=3 ; level=10 

a=framesize: 96 176-144 

a=FEC:0 

a=maxprate : 15 

m=audio 4004 UDP/MBMS-FEC/RTP/AVP 98 

b=TIAS: 11500 

b=RR: 

b=RS:300 

a=rtpmap:98 AMR/8000 

a=fmtp:98 octet-align=l 

a=FEC:0 

a=maxprate : 10 

The FEC stream used to protect the above RTP sessions and a MIKEY key stream has the below SDP 
(http://www.example.com/3gpp/mbms/sessionl-fec.sdp): 

v=0 

o=ghost 2890844526 2890842807 IN IP6 2001 : 210 : 1 : 2 : 240 : 96FF : FE25 : 8EC9 

s=3GPP MBMS Streaming FEC SDP Example 

i=Example of MBMS streaming SDP file 

u=http : //www. infoserver. example . com/ae6 

e=ghost@mailserver . example . com 

C=IN IP6 FF1E:03AD: :7F2E:172A:1E24 

t=3034423619 3042462419 

b=AS:15 

a=FEC-declaration: encoding-id=l 

a=FEC-OTI-extension: ACAEAA== 

a=mbms -repair: min-buf f er-time=2600 

a=source-filter: incl IN IP6 * 2001 : 210 : 1 : 2 : 240 : 96FF : FE25 : 8EC9 

m=application 4006 UDP/MBMS -REPAIR * 

b=AS:15 

a=FEC:0 

a=mbms-flowid: 1=FF1E:03AD: : 7F2E : 172A: 1E24/4002 , 2=FF1E:03AD: : 7F2E : 172A: 1E24/4003 , 

3=FF1E:03AD: : 7F2E : 172A: 1E24/4004 , 4=FF1E:03AD: : 7F2E : 172A: 1E24/4005 , 5=FF1E:03AD: : 7F2E : 172A: 1E24/2269 
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8.3 Session description 

SDP is provided to the MB MS client via a discovery/announcement procedure to describe the streaming dehvery 
session. The SDP describes one or more RTF session part of the MBMS streaming session. The SDP shall be a 
correctly formed SDP according to RFC 2327 [14]. 

8.3.1 SDP Parameters for MBMS streaming session 

The semantics of a Session Description of an MBMS streaming session shall include the parameters: 

The sender IP address. 

The number of media in the session. 

The destination IP address and port number for each and all of the RTP sessions in the MBMS streaming 
session. 

The start time and end time of the session. 

The protocol ID (i.e. RTP/AVP). 

Media type(s) and fmt-list. 

Data rate using existing SDP bandwidth modifiers. 

Mode of MBMS bearer per media. 

FEC configuration and related parameters. 

Service-language(s) per media. 

QoE Metrics (defined in sub-clauses 8.3.2.1 and 8.4). 

8.3.1.1 Sender IP address 

There shall be exactly one IP source address per media description within the SDP. The IP source address shall be 
defined according to the source-filter attribute ("a=source-filter:") [15] for both IPv4 and IPv6 sources, with the 
following exceptions: 

1. Exactly one source address may be specified by this attribute such that exclusive-mode shall not be used and 
inclusive-mode shall use exactly one source address in the <src-list>. 

2. There shall be exactly one source-filter attribute per complete MBMS streaming session SDP description, and 
this shall be in the session part of the session description (i.e. not per media). 

3. The * value shall be used for the <dest-address> subfield. 

8.3.1 .2 Destination IP address and port number for channels 

Each RTP session part of a MBMS streaming session is defined by two parameters: 

• IP destination address. 

• Destination port number(s). 

The IP destination address shall be defined according to the "connection data" field ("c=") of RFC 2327 [14]. The 
destination port number shall be defined according to the <port> sub-field of the media announcement field ("m=") of 
RFC 2327 [14]. Multiple ports using "/" notation shall not be used. The RTCP port, if used, shall be RTP port +1. 
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8.3.1 .3 Media Description 

The media description line shall be used as defined in RFC 2327 [14] for RTP. The <media> part indicates the type of 
media, audio, video, or text. The usage of RTP and any applicable RTP profile shall be indicated by using the <proto> 
field of the 'm-line'. The one or more payload types that are being used in this RTP session are enumerated in the <fmt> 
part. Each payload type is declared using the "a=rtpmap" attribute according to RFC 2327 [14] and use the "a=fmtp" 
line when required to describe the payload format parameters. 

8.3.1 .4 Session Tinning Parameters 

A MBMS streaming session start and end times shall be defined according to the SDP timing field ("t=") - 
RFC 2327 [14]. 

8.3.1 .5 Mode of MBMS bearer per media 

The MBMS bearer mode declaration attribute shall be used for MBMS streaming sessions, as defined in sub-clause 

7.3.2.7. 

8.3.1 .6 Service-language(s) per media 

The existing SDP attribute "a=lang" is used to label the language of any language-specific media. The values are taken 
from RFC 3066 [73] which in turn takes language and (optionally) country tags from ISO 639 [74] and ISO 3166 [75] 
(e.g. "a=lang: EN-US"). These are the same tags used in the User Service Description XML. 

8.3.1 .7 Bandwidth specification 

The bit-rate required by the MBMS streaming session and its media components shall be specified using both the "AS" 
bandwidth modifier and the "TIAS" bandwidth modifier combined with "a=maxprate" [31] on media level in the SDP. 
On session level the "TIAS" bandwidth modifier combined with "a=maxprate" may be used. Where the session level 
expresses the aggregated peak bit-rate, which may be lower than the sum of the individual media streams. 

The bandwidth required for RTCP is specified by the "RR" and "RS" bandwidth modifiers (3GPP TS 26244 [32]) on 
media level for each RTP session. The "RR" modifier shall be included and set to to specify that RTCP receiver 
reports are not used. The bandwidth used for RTCP sender reports shall be specified using the "RS" bandwidth 
modifier. 

8.3.1.8 FEC Parameters 

The FEC encoding ID and instance ID is provided using the "a=FEC-declaration" attribute defined in sub-clause 
7.3.2.8. Any OTI information for that FEC encoding ID and instance ID is provided with below defined FEC OTI 
attribute. 

The FEC OTI attribute must be immediately preceded by the "a=FEC-declaration" attribute (and so can be session-level 
and media-level). The fec-ref maps the oti-extension to the EEC-declaration OTI it extends. The purpose of the oti- 
extension is to define FEC code specific OTI required for RTP receiver FEC payload configuration, exact contents are 
FEC code specific and need to be specified by each FEC code using this attribute. The OTI for the MBMS FEC Scheme 
is defined in sub-clause 8.2.2.10a. 

The syntax for the attributes in RFC 4234 [23] is: 

• sdp-fec-oti-extension-line = "a=FEC-OTI-extension:" fec-ref SP oti-extension CRLF 

• fec-ref = 1 *3DIGIT (the SDP-internal identifier for the associated EEC-declaration). 

• oti-extension = base64 

• base64 = *base64-unit [base64-pad] 

• base64-unit = 4base64-char 

• base64-pad = 2base64-char "==" / 3base64-char "=" 
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• base64-char = ALPHA / DIGIT /"+"/ 7" 

To provide the FEC repair packets with additional, non FEC specific parameters, a session and media level SDP 
attribute is defined. 

sdp-fec-parameter-line = 'a=mbms-repair: 0*1SP fec-ref SP parameter-list CRLF 

parameter-list = parameter- spec *(1*SP parameter-spec) 

parameter-spec = name '=' value; 

name = 1 *(ALPHA / DIGIT / '-') 

value = l*(safe) ; safe defined in RFC 2327 

Currently one FEC non code-specific parameter is defined: 

min-buffer-time: This FEC buffering parameter specifies the minimum receiver buffer time (delay) needed to ensure 
that FEC repair has time to happen regardless of the FEC source block of the stream from which the reception 
starts. The value is in milliseconds and represents the wallclock time between the reception of the first FEC 
source or repair packet of a FEC source block, whichever is earlier in transmission order, and the wallclock time 
when media decoding can safely start. 

The parameters name and value is defined in ABNF as follows: 

Min-buffer-time-parameter-name = 'min-buffer-time' 

Min-buffer-time -parameter- value = 1*8DIGIT ; Wallclock time in milliseconds. 

The FEC declaration and FEC OTI information utilized in a specific source or repair packet is indicated using the FEC- 
ref number in the a=fec lines as described in sub-clauses 8.2.2.12 and 8.2.2.13. 

8.3.1.9 FEC Flow ID attribute 

To indicate the mapping between destination IP address and UDP port number and FEC source block flow IDs, the 
'a=mbms-flowid' SDP attribute is defined. Each flowID that may be used in source block within the bundled sessions 
shall be included. It is a media level attribute that shall be present in any SDP media block using the 'UDP/MBMS- 
REPAIR' protocol identifier. 

The syntax for the attributes in ABNF [23] is: 

Sdp-mbms-flowid-attr = "a=mbms-flowid:" *WSP flow-id-spec *("," *WSP flow-id-spec) CRLF 

flow-id-spec = flowID "=" address-spec "/" port-spec 

address-spec = IP4-multicast / IP6-multicast 

IP4-multicast = ml 3*( "." decimal-uchar ) 

ml = ("22" ("4"/"5"/"6"/"7"/"8"/"9")) / ("23" DIGIT )) 

IP6-multicast = hexpart 

hexpart = hexseq / hexseq "::" [ hexseq ] / 

"::" [hexseq] 

hexseq = hex4 *( ":" hex4) 

hex4 = 1*4HEXDIG 

port-spec = 1*5DIGIT 

8.3.2 SDP Example for Streaming Session 

Here is a full example of SDP description describing the media streams part of a streaming delivery session: 
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v=0 

o=ghost 2890844526 2890842807 IN IP4 192.168.10.10 

s=3GPP MBMS Streaming SDP Example 

i=Example of MBMS streaming SDP file 

u=http : //www. infoserver . example . com/ae6 

e=ghost@mailserver . example . com 

C=IN IP6 FFIE: 03 AD : : 7F2E : 1 72A : 1E24 

t=3034423619 3042462419 

b=AS:77 

a=mbms -mode : broadcast 1234 1 

a=source-filter: incl IN IP6 * 2001 : 210 : 1 : 2 : 240 : 96FF : FE25 : 8EC9 

m=video 4 02 RTP/AVP 96 

b=TIAS:62000 

b=RR:0 

b=RS:600 

a=maxprate : 17 

a=rtpmap:96 H264/90000 

a=fmtp : 96 prof ile-level-id=42A01E ; packetization-mode=l ; sprop-parameter-sets=ZOIACpZTBYmI , aMlj iA= = 

m=audio 4004 RTP/AVP 98 

b=TIAS: 15120 

b=RR: 

b=RS:600 

a=maxprate : 10 

a=rtpmap:98 AMR/8000 

a=fmtp:98 octet-align=l 

FEC is not used in that example. See clause 8.2.2.15 for an example with FEC. 



8.3.2.1 SDP Description for QoE IVIetrics 

Similar as in 3GPP TS 26.234 [47], an SDP attribute for QoE, which can be used either at session or media level, is 
defined below in RFC 4234 [23] based on RFC 2327 [14]: 

• QoE-Metrics-line = "a" "=" "3GPP-QoE-Metrics:" att-measure-spec *("," att-measure-spec)) CRLF 

• att-measure-spec = Metrics ";'' Sending-rate [";'' Measure-Range] *([";'' Parameter-Ext]) 

• Metrics = "metrics" "=" "{"Metrics-Name *("!" Metrics-Name) " }" 

• Metrics-Name = I*((0x21..0x2b) / (0x2d..0x3a) / (0x3c..0x7a) / 0x7e) ;VCHAR except ";", ",", "{" or "}" 

• Sending-Rate = "rate" "=" 1*DIGIT / "End" 

• Measure-Range = "range" ":" Ranges-Specifier 

• Parameter-Ext = (PDIGIT ["." 1*DIGIT]) / (I*((0x21..0x2b) / (0x2d..0x3a) / (0x3c..0x7a) / 0x7c / 0x7e)) 

• Ranges-Specifier = as defined in RFC 2326 [76]. 

An MBMS server uses this attribute to indicate that QoE metrics are supported and shall be used if also supported by 
the MBMS client. When present at session level, it shall only contain metrics that apply to the complete session. When 
present at media level, it shall only contain metrics that are applicable to individual media. 

The "Metrics" field contains the list of names that describes the metrics/measurements that are required to be reported in 
a MBMS session (see sub-clause 8.4). The names that are not included in the "Metrics" field shall not be reported 
during the session. 

In this version of the specification, the "Sending-Rate" shall be set to the value "End", which indicates that only one 
report is sent at the end of the MBMS session. 

The optional "Measure-Range" field, if used, shall define the time range in the stream for which the QoE metrics will be 
reported. There shall be only one range per measurement specification. The range format shall be any of the formats 
allowed by the media. If the "Measure-Range" field is not present, the corresponding (media or session level) range 
attribute in SDP shall be used. If SDP information is not present, the metrics range shall be the whole session duration. 
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8.4 Quality of Experience 

8.4.1 General 

The MBMS Quality of Experience (QoE) metrics feature is optional for both MBMS streaming server and MBMS 
client, and shall not disturb the MBMS service. An MBMS Server that supports the QoE metrics feature shall activate 
the gathering of client QoE metrics with SDP as described in sub-clauses 8.3.2.1 and 8.4.2 and via the reception 
reporting procedure as described in sub-clause 9.4. An MBMS client supporting the feature shall perform the quality 
measurements in accordance to the measurement definitions, aggregate them into client QoE metrics and report the 
metrics to the MBMS server using the content reception reporting procedure. The way the QoE metrics are processed 
and made available is out of the scope of the present document. 

8.4.2 QoE Metrics 

An MBMS client should measure the metrics at the transport layer after EEC decoding (if EEC is used), but may also do 
it at the application layer for better accuracy. 

The reporting period for the metrics is the whole streaming duration. This duration may be less than the session 
duration, because of late joiners or early leavers. The reporting period shall not include any voluntary event that impacts 
the actual play, such as pause, or any buffering or freezes/gaps caused by them. 

The following metrics shall be derived by the MBMS client implementing QoE. All the metrics defined below are only 
applicable to at least one of audio, video, speech and timed text media types, and are not applicable to other media types 
such as synthetic audio, still images, bitmap graphics, vector graphics, and text. Any unknown metrics shall be ignored 
by the client and not included in any QoE report. Among the QoE metrics, corruption duration, successive loss of RTP 
packets, frame-rate deviation and jitter duration are of media level, whereas initial buffering duration and rebuff ering 
duration are of session level. 

8.4.2.1 Corruption duration metric 

Corruption duration, M, is the time period from the NPT time of the last good frame before the corruption, to the NPT 
time of the first subsequent good frame or the end of the reporting period (whichever is sooner). A corrupted frame may 
either be an entirely lost frame, or a media frame that has quality degradation and the decoded frame is not the same as 
in error- free decoding. A good frame is a "completely received" frame X that, either: 

• it is a refresh frame (does not reference any previously decoded frames AND where none of the subsequently 
decoded frames reference any frames decoded prior to X); or 

• does not reference any previously decoded frames; or 

• references previously decoded "good frames". 

"Completely received" means that all the bits are received and no bit error has occurred. 
Corruption duration, M, in milliseconds can be calculated as below: 

a) M can be derived by the client using the codec layer, in which case the codec layer signals the decoding of a 
good frame to the client. A good frame could also be derived by error tracking methods, but decoding quality 
evaluation methods shall not be used. 

b) In the absence of information from the codec layer, M should be derived from the NPT time of the last frame 
before the corruption and N, where N is optionally signalled from MBMS streaming server (via SDP) to the 
MBMS client and represents the maximum duration between two subsequent refresh frames in milliseconds. 

c) In the absence of information from the codec layer and if N is not signalled, then M defaults to oo (for video) or 
to one frame duration (for audio), or the end of the reporting period (whichever is sooner). 

The optional parameter N as defined in point b is used with the "Corruption_Duration" parameter. Another optional 
parameter T is defined to indicate whether the client uses error tracking or not. The value of T shall be set by the client 
via reception reporting (sub-clause 9.5.3) as on or off. The syntax for N to be included in the "att-measure-spec" (sub- 
clause 8.3.2.1) is as follows: 
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• N = "N""=" 1*DIGIT 

In MBMS reception reporting will be done only once at the end of streaming, hence all the occurred corruption 
durations are summed up over the period of the stream as the value TotalCorruptionDuration. The unit of this metrics is 
expressed in milliseconds. The number of individual corruption events over the stream duration are summed up in the 
value NumberOfCorruptionEvents. These two values are reported by the MBMS client as part of the reception report 
(sub-clauses 9.4.6 and 9.5.3). 

8.4.2.2 Rebuffering duration metric 

Rebuff ering is defined as any stall in playback time due to any involuntary event at the client side. 

The syntax for the metric "Rebuffering_Duration" for the QoE-Feedback header is as defined in sub-clause 8.3.2.1. 

Rebuffering starts at the NPT time of the last played frame before the occurrence of the rebuffering. 

In MBMS reception reporting will be done only once at the end of streaming, hence all the occurred rebuffering 
durations are summed up over the period of the stream as the value TotalRebujferinfDuration. The unit of this metrics is 
expressed in seconds, and can be a fractional value. The number of individual rebuffering events over the stream 
duration are summed up in the value NumberOfRebujferingEvents. These two values are reported by the MBMS client 
as part of the reception report (sub-clauses 9.4.6 and 9.5.3). 

8.4.2.3 Initial buffering duration metric 

Initial buffering duration is the time from receiving the first RTP packet until playing starts. 

The syntax for the "Initial_Buffering_Duration" is as defined in sub-clause 8.3.2.1. 

If the reporting period is shorter than the "Initial_Buffering_Duration" then the MBMS client should send this 
parameter for the reporting period as long as it observes it. The metric value indicates the initial buffering duration 
where the unit of this metrics is expressed in seconds, and can be a fractional value. There can be only one measure and 
it can only take one value. "Initial_Buffering_Duration" is a session level parameter.This value is reported by the 
MBMS client as part of the reception report (sub-clauses 9.4.6 and 9.5.3). 

8.4.2.4 Successive loss of RTP packets 

The metric "Successive_Loss" indicates the number of RTP packets lost in succession (excluding FEC packets) per 
media channel. 

The syntax for the metrics "Successive_Loss" is as defined in sub-clause 8.3.2.1. 

In MBMS reception reporting will be done only once at the end of streaming, hence all the number of successively lost 
RTP packets are summed up over the period of the stream as the value TotalNumberofSuccessivePacketLoss. The unit 
of this metric is expressed as an integer equal to or larger than 1. The number of individual events over the stream 
duration are summed up in the value NumberOfSuccessiveLossEvents. These two values are reported by the MBMS 
client as part of the reception report (sub-clauses 9.4.6 and 9.5.3). 

8.4.2.5 Frame rate deviation 

Frame rate deviation indicates the playback frame rate information. Frame rate deviation happens when the actual 
playback frame rate during a reporting period is deviated from a pre-defined value. 

The actual playback frame rate is equal to the number of frames played during the reporting period divided by the time 
duration, in seconds, of the reporting period. 

The parameter FR that denotes the pre-defined frame rate value is used with the "Framerate_Deviation" parameter in 
the "3GPP-QoE-Metrics" attribute. The value of FR shall be set by the server. The syntax for FR to be included in the 
"att-measure-spec" (sub-clause 8.3.2.1) is as follows: 

• FR = "FR" "=" 1*DIGIT "." PDIGIT 

The syntax for the metric "Framerate_Deviation" is defined in sub-clause 8.3.2.1. 
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For the Metrics -Name "Framerate_Deviation", the value field indicates the frame rate deviation value that is equal to 
the pre-defined frame rate minus the actual playback frame rate. This metric is expressed in frames per second, and can 
be a fractional value, and can be negative. This value is reported by the MBMS client as part of the reception report 
(sub-clauses 9.4.6 and 9.5.3). 

8.4.2.6 Jitter duration 

Jitter happens when the absolute difference between the actual playback time and the expected playback time is larger 
than a pre-defined value, which is 100 milliseconds. The expected time of a frame is equal to the actual playback time 
of the last played frame plus the difference between the NPT time of the frame and the NPT time of the last played 
frame. 

The syntax for the metric "Jitter_Duration" is defined in sub-clause 8.3.2.1. 

In MBMS reception reporting will be done only once at the end of streaming, hence all the Jitter_Durations are summed 
up over the period of the stream as the value TotalJitterDuration. The unit of this metrics is expressed in seconds, and 
can be a fractional value. The number of individual events over the stream duration are summed up in the value 
Number Of Jitter Events. These two values are reported by the MBMS client as part of the reception report (sub-clauses 
9.4.6 and 9.5.3). 

8.4.3 Example metrics initiation with SDP 

This following example shows the syntax of the SDP attribute for QoE metrics. The session level QoE metrics 
description (Initial buffering duration and rebufferings) are to be monitored and reported only once at the end of the 
session. Also video specific description of metrics (corruptions) are to be monitored and reported at the end from the 
beginning of the stream until the time 40s. Finally, audio specific description of metrics (corruptions) is to be monitored 
and reported at the end from the beginning until the end of the stream. 

SDP example: 

v=0 

o=- 3268077682 433392265 IN IP4 63.108.142.6 

s=QoE Enabled Session Description Example 

e=support@f oo . com 

c=lN 1P4 0.0.0.0 

t = 

a=range:npt=0-83 .660000 

a=3GPP-QoE-Metrics : { lnitial_Buf f ering_Duration | Rebuff ering_Duration} ; rate=End 

a=control : * 

m=video RTP/AVP 96 

b=AS:28 

a=3GPP-QoE-Metrics : { Corrupt ion_Durat ion} ; rate=End; range :npt=0-40 

a=control : tracklD=3 

a=rtpmap:96 MP4V-ES/1000 

a=range:npt=0-83 .666000 

a=fmtp:96profile- level -id=8;config=000001b008000001b50900012 000 

m=audio RTP/AVP 98 

b=AS:13 

a=3GPP-QoE-Metrics : { Corrupt ion_Durat ion} ;rate=End 

a=control : trackID=5 

a=rtpmap:98 AMR/8000 

a=range:npt=0-83 .660000 

a=fmtp:98 octet-align=l 

a=maxpt ime : 2 



Associated delivery procedures 



9.1 Introduction 

Associated delivery procedures describe general procedures, which start before, during or after the MBMS data 
transmission phase. They provide auxiliary features to MBMS user services in addition, and in association with, 
MBMS delivery methods and their sessions. Those procedures that shall only be permitted after the MBMS Data 
transmission phase may also be described as post-delivery procedures. 
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To enable future backwards compatibility beyond 3GPP MBMS release 6 specifications, clause 9specifies generic and 
extensible techniques for a potentially wide range of associated delivery procedures. 

Clauses 9.3 and 9.4 the associated delivery procedures that are included in release 6, and are initiated only after an 
MBMS data transmission phase. 

The present document describes these associated delivery procedures: 

• File repair, for post-delivery repair of files initially delivered as part of an MBMS download session. 

• Content reception reporting of files delivered to an MBMS UE. 

These procedures are enabled by establishing a point-to-point connection; and using the MBMS session parameters, 
received during User Service Discovery/Announcement, to communicate the context (e.g. file and session in question) 
to the network and the MBMS sender infrastructure. To avoid network congestion in the uplink and downlink 
directions, and also to protect servers against overload situations, the associated delivery procedures from different 
MBMS UEs shall be distributed over time and resources (network elements). 

An instance of an "associated procedure description" is an XML file that describes the configuration parameters of one 
or more associated delivery procedures. 

MBMS Download receivers shall support the file repair procedure as defined in sub-clause 9.3. 

MBMS Download receivers shall support the reception reporting procedure as defined in sub-clause 9.4. 

MBMS Streaming receivers shall support reception reporting procedures (StaR and StaR-all report types) as defined in 
sub-clause 9.4. 

9.2 Associated Procedure Description 

An associated procedure description instance (configuration file) for the associated delivery procedures may be 
dehvered to the MBMS chents: 

• during a User Service Discovery / Announcement prior to the MBMS Download delivery session along with the 
session description (out-of-band of that session); or 

• in-band within a MBMS Download delivery session. 

The most recently delivered configuration file (i.e. the one with the highest version number - as given from the 
envelope, see sub-clause 11.1.3) shall take priority, such that configuration parameters received prior to, and out-of- 
band of, the download session they apply to are regarded as "initial defaults", and configuration parameters received 
during, and in-band with the download session, overwrite the earlier received parameters. Thus, a method to update 
parameters dynamically on a short time-scale is provided but, as would be desirable where dynamics are minimal, is not 
mandatory. 

During the User Service Discovery / Announcement Procedure, the associated procedure description instance is clearly 
identified using a URI, to enable UE cross-referencing of in and out-of-band configuration files. 

The MIME application type "application/mbms-associated-procedure-description+xml" as defined in clause C.7 
identifies associated delivery procedure description instances (configuration files). 

In XML, each associated delivery procedure entry shall be configured using an "associatedProcedureDescription" 
element. All configuration parameters of one associated delivery procedure are contained as attributes of an 
"associatedProcedureDescription" element. The elements (e.g. "postFileRepair" and "postReceptionReport") of 
an "associatedProcedureDescription" element identify which associated procedure(s) to configure. The associated 
delivery procedure description is specified formally as an XML schema in sub-clause 9.5.1. 
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9.3 File Repair Procedure 

9.3.1 Introduction 

The purpose of the File Repair Procedure is to repair lost or corrupted file fragments from the MBMS download data 
transmission. When in multicast/broadcast environment, scalability becomes an important issue as the number of 
MBMS clients grows. Three problems must generally be avoided: 

• Feedback implosion due to a large number of MBMS clients requesting simultaneous file repairs. This would 
congest the uplink network channel. 

• Downlink network channel congestion to transport the repair data, as a consequence of the simultaneous clients 
requests. 

• File repair server overload, caused again by the incoming and outgoing traffic due to the clients' requests arriving 
at the server, and the server responses to serve these repair requests. 

The three problems are interrelated and must be addressed at the same time, in order to guarantee a scalable and 
efficient solution for MBMS file repair. 

The principle to protect network resources is to spread the file repair request load in time and across multiple servers. 

The MBMS chent: 

1 . Identifies the end of transmission of files or sessions. 

2. Identifies the missing data from an MBMS download. 

3. Calculates a random back-off time and selects a file repair server randomly out of a list. 

4. Sends a repair request message to the selected file repair server at the calculated time. 

When a MBMS download session of repair data is configured in the associated delivery descriptions, a MBMS client 
should wait for repair data in the defined MBMS download session on its MBMS bearer - except where the UE is 
prevented from doing so due to limited simultaneous context activation capability. 

Then the file repair server: 

1. Responds with a repair response message either containing the requested data, redirecting the client to an 
MBMS download session, redirecting the client to another server, or alternatively, describing an error case. 

The BM-SC may also send the repair data on a MBMS bearer (possibly the same MBMS bearer as the original 
download) as a function of the repair process. 

The random distribution, in time, of repair request messages enhances system scalability to the total number of such 
messages the system can handle without failure. 

9.3.2 Starting Time of the Associated Delivery Procedure for MBMS 
Download Delivery 

FLUTE File Delivery Table (FDT) Instances include an "expires" attribute, which defines the expiration time of the 
FDT instance. The sender must use an expiry time relative tothe current time at the BM-SC. According to 
RFC 3926 [9], "the receiver SHOULD NOT use a received FDT Instance to interpret packets received beyond the 
expiration time of the FDT Instance". 

The starting time of Associated Delivery Procedure for the MBMS download is the expiration time of the FDT instance 
at the latest. 

The MBMS UE may also choose to start the Associated Delivery Procedure before the FDT instance expires 

• when it has received an end-of-object (B-flag) for an object or 
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• when an end-of-session (A-flag) is received before the FDT instance expires. Note, the end-of session (A- 
flag) indicates, that no more objects nor FDT instances will be transmissed by the BM-SC. 

If the MBMS UE is not capable of receiveing an MEMS transmission while using an interactive bearer, the MBMS UE 
shall ignore the end-of-object flags (B-flag). 

When a particular file (URI) is present in several FDT Instances with different TOI values, then the FDT Instance with 
the highest FDT Instance ID defines the TOI for the most recent instance of the file and determines the end of 
transmission time for that file. A UE shall only determine transmission completeness for a file for the most recent 
instance of the file - and shall not use FDT Instance expiry time to determine transmission completeness for any other 
(TOI) instances of a file (fileURI). 

NOTE 1 : The intention of this sub-clause is to just start the Associated Delivery Procedure back-off timer for the 
more recent instance version of a file with respect to the FLUTE transmission session. 

When a particular file (URI) is present in more than one FDT Instance with the same TOI value, then the end of 
transmission time is defined by the expiration time of the latest FDT Instance to expire. 

If an FDT Instance is received describing the file after this time (giving an FDT Instance expiry time in the future and a 
different TOI value) the UE shall determine that the transmission of the file is incomplete - i.e. that more packets may 
arrive within the MBMS download session for that file, 'forgetting' its previous file transmission complete 
determination. 

NOTE 2: This effectively resets and stops any running timers already initiated for an associated delivery procedure 
for that file. 

If the MBMS UE receives an end-of-object packet (with FLUTE header B flag set true) the MBMS UE shall determine 
that the transmission of that object is complete, and shall interpret that as file transmission complete if no, more recent, 
TOIs are described for the same file (URI) in any received and unexpired FDT Instance(s). 

If the MBMS UE determines that the download session is complete (as specified in sub-clause 9.4.2) then it shall 
interpret this also that all the transmissions of all files (and TOIs) described by all FDT Instances, received from that 
session, are complete. 

9.3.3 Identification of Missing Data from an MBMS Download 

The session description and (in-band) the MBMS download delivery protocol, FLUTE, provide the client with 
sufficient information to determine the source block and encoding symbol structure of each file. From this a client is 
able to determine which source symbols should have been transmitted but have not been received. The client is also 
able to determine the number of symbols it has received for each source block of each file, and thus the number of 
further symbols required to decode the block. 

Thus, an MBMS client is able to identify any source symbols lost in transmission, and the number (and ESI values 
where appropriate) of required source and/or repair symbols that would complete the reconstruction of a source block 
(of a file). 

Where the MBMS EEC scheme is used, the MBMS client shall consider already received repair symbols when making 
the determination of the further symbols required. In this case, the client should either: 

• - identify a minimal set of specific symbols that, combined with the already received symbols, 
allow the MBMS FEC decoder to recover the file, or 

• - identify a number, r, of symbols such that reception of r previously unreceived symbols will 
allow the MBMS FEC decoder to recover the file. 

9.3.4 Back-off Timing the Procedure Initiation Messaging for Scalability 

This clause describes a back-off mode for MBMS download to provide information on when a receiver, that did not 
correctly receive some data from the MBMS sender during a transmission session, can start a request for a repair 
session. In the following it is specified how the information and method a MBMS client uses to calculate a time 
(back-off time), instance of the back-off mode, to send a file repair message to the MBMS server. 
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The back-off mode is represented by a back-off unit, a back-off value, and a back- off window. The two latter parameters 
describe the back-off time used by the MB MS client. 

The back-off unit (in the time dimension) defaults to seconds and it is not signalled. 

The back-off time shall be given by an offset time (describing the back-off value) and a random time period (describing 
the back-off window) as described in the following clauses. 

An MBMS client shall generate random or pseudo-random time dispersion of repair requests to be sent from the 
receiver (MBMS client) to the sender (MBMS server). In this way, the repair request is delayed by a pre-determined 
(random) amount of time. 

The back-off timing of repair request messages (i.e. delaying the sending of repair requests at the receiver) enhances 
system scalability to the total number of such messages the system can handle without failure. 

9.3.4.1 Offset time 

The OffsetTime refers to the repair request suppression time to wait before requesting repair, or in other words, it is the 
time that a MBMS client shall wait after the end of the MBMS data transmission to start the file repair procedure. An 
associated procedure description instance shall specify the wait time (expressed in back-off unit) using the "offset-time" 
attribute. 

9.3.4.2 Random Time Period 

The Random Time Period refers to the time window length over which a MBMS client shall calculate a random time for 
the initiation of the file repair procedure. The method provides for statistically uniform distribution over a relevant 
period of time. An associated procedure description instance shall specify the wait time (expressed in back-off unit) 
using the "random-time-period" attribute. 

The MBMS client shall calculate a uniformly distributed Random Time out of the interval between and Random Time 
Period. 

9.3.4.3 Back-off Time 

The sending of the file repair request message shall start at Back-off Time = offset-time + Random Time, and this 
calculated time shall be a relative time after the MBMS data transmission. The MBMS client shall not start sending the 
repair request message before this calculated time has elapsed after the initial transmission ends. 

9.3.4.4 Reset of the Back-off Timer 

The reception of an updated (higher version number) associatedDeliveryProcedureDescription and/or an updated 
sessionDescription shall overwrite the timer parameters used in the back-off algorithm. Except in the case that the 
offset-time, random-time-period and session end time parameters are identical to the earlier version; the back-off time 
shall be recalculated. For currently running timers this requires a reset. 

9.3.5 File Repair Server Selection 

9.3.5.1 List of Server URIs 

A list of file repair service URIs is provided as elements of the Associated Delivery procedure fragment's 
postFileRepair element. Service URIs host identity may also be given as IP addresses, which may be used to avoid a 
requirement for DNS messaging. The file repair service URIs of a single associated delivery procedure description shall 
be of the same type, e.g. all IP addresses of the same version, or all domain names. The number of URIs is determined 
by the number of "serviceURI" elements, each of which shall be a child-element of the "procedure" element. The 
"serviceURI" element provides the references to the file repair server's resource via the "xs:anyURI" value. At least one 
"serviceURI" element shall be present. 

9.3.5.2 Selection from the Server URI List 

The MBMS client randomly selects one of the service URIs from the list, with uniform distribution. 
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9.3.6 File Repair Request Message 

Once missing file data is identified, the MBMS client sends one or more messages to a file repair server requesting 
transmission of data that allows recovery of missing file data. All file repair requests and repair responses for a 
particular MBMS transmission shall take place in a single TCP session using the HTTP protocol (RFC 2616 [18]). The 
repair request is routed to the file repair server IP address resolved from the selected "serviceURI". 

The timing of the opening of the TCP connection to the server, and the first repair request, of a particular MBMS client 
is randomized over a time window as described in sub-clause 9.3.2. If there is more than one repair request to be made 
these are sent immediately after the first. 

When a MBMS UE identifies symbols in repair requests these shall be source symbols, and should include all the 
missing source symbols of the relevant source block. Note, these represent information for the file repair server and the 
BM-SC may use these and/or redundant symbols in providing the necessary repair data. 

9.3.6.1 File Repair Request Message Format 

After the MBMS download session, the receiver identifies a set of encoding symbols which allows recovery of the 
missing file data and requests for their transmission in a file repair session. Specific encoding symbols are uniquely 
identified by the combination (URI, SBN, ESI). 

The file repair request shall include the URI of the file for which it is requesting the repair data. URI is required to 
uniquely identify the file (resource) and is found from the download delivery method (the FLUTE FDT Instances 
describe file URIs). Additionally, the repair request shall contain an indication of the MD5 hash value of the file, if 
present in the FDT instance declaring the file from which data is being requested. The MD5 hash value is used to 
identify a specific version of the file. The (SBN, ESI) pair uniquely identifies an encoding symbol. For completely 
missed files, a Repair Request may give only the URI of the file and optionally the MD5 hash value of the file. If the 
MD5 hash value is not present, the server shall respond with the latest version of the file. 

The client makes a file repair request using the HTTP (RFC 2616 [18]) request method GET. If specific symbols are 
requested, the (SBN, ESI) of requested encoding symbols are encoded into the URI query part (RFC 3986 [19]) as 
defined below and included in the HTTP GET request. If a number of previously unreceived symbols are requested for 
a specific Source Block, then the SBN is provided along with the ESI of the symbol, which is subsequent in the symbol 
sequence to the latest received symbol for that source block and the number of symbols requested. If a number of 
previously unreceived source blocks are requested for a specific file, the URI should be provided along with an SBN 
range starting from the first missing source block and ending with the SBN of the last missing source block of the 
contiguous set of source block. Examples for requesting contiguous and non-contiguous ranges of symbols and source 
blocks or even an entire file are given below. 

For example, assume that in a MBMS download session a 3gp file with URI = www.example.com/news/latest.3gp was 
delivered to an MBMS client. After the MBMS download session, the MBMS client recognized that it did not receive 
two packets with SBN = 5, ESI = 12 and SBN=20, ESI = 27. If the repair service URI (from the associated delivery 
procedure meta data fragment) is http://mbmsrepairl.example.com/path/repair script and the MD5 value of that file is 
'ODZiYTU10TFkZGY2NWY50Dh==', then the HTTP GET request is as follows: 

GET /path/repair_script?fileURI=www.example.com/news/latest.3gp&Content-MD5= 
ODZiYTUlOTFkZGY2NWY5ODh==&SBN=5;ESI=12&SBN=20;ESI=27 HTTP/1.1 

Host: mbmsrepairl.example.com 

A file repair session shall be used to recover the missing file data from a single MBMS download session only. If more 
than one file were downloaded in a particular MBMS download session, and, if the MBMS client needs repair data for 
more than one file received in that session, the MBMS client shall send separate HTTP GET requests for each file. 

An HTTP client implementation might limit the length of the URL to a finite value, for example 256 bytes. In the case 
that the length of the URL-encoded (SBN, ESI) data exceeds this limit, the MBMS client shall distribute the 
URL-encoded data into multiple HTTP GET requests. 

In any case, all the HTTP GETs of a single file repair session shall be performed within a single TCP session and they 
shall be performed immediately one after the other. 

In the following, we give the details of the syntax used for the above request method in ABNF. 
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In this case an HTTP GET with a normal query shall be used to request the missing data, according to HTTP 1.1 
[RFC2616 [18]] 

• repair_request_http_URL = repair_service_URI "?" query 

• repair_service_URI = <selected serviceURI from the Associated Delivery Procedure Description> 
Where, for MBMS File Repair Request: 

• query = file_uri ["&" content_md5] *( "&" sbnjnfo) 

• file_uri = "fileURI=" URI-reference; URI-reference is as defined in [19]. 

• content_md5 = "Content-MD5=" 1*(ALPHA / DIGIT / "+" / 7" / "=") 

• sbnjnfo = "SBN=" sbn_range 

• sbn_range = ( sbnA [ "-" sbnZ ] ) / ( sbnA [ ";'' esi_info] ) 

• esi_info = "ESI=" ((esi_range *( "," esi_range ) ) ) / (esiA '+' number_symbols) 

• esi_range = esiA [ "-" esiZ ] 

• sbnA = 1 *DIGIT; the SBN, or the first of a range of SBNs 

• sbnZ = 1 *DIGIT; the last SBN of a range of SBNs 

• esiA = 1 *DIGIT; the ESI, or the first of a range of ESIs 

• esiZ = 1 *DIGIT; the last ESI of a range of ESIs 

• number_symbols = 1 *DIGIT; the number of additional symbols required 

Thus, the following symbols adopt a special meaning for MBMS download URI: ?- + ,;& = 

One example of a query on encoding symbol 34 of source block 12 of a music file 
'www.example.comm/greatmusic/numberl.aac" using the provided repair service URI 
"http://mbmsrepairl .example.com/path/repair_script" is: 

• http ://mbmsrepair 1 . example. com/path/repair_script?fileURI= 
www.example.com/greatmusic/numberl. aac&SBN=12;ESI=34 

An example of requesting an entire file is 

• http : //mbmsrepair 1 . example . com/path/repair_script ?fileURI= www . example . com/greatmusic/number 1 . aac 

An example of requesting a specific source block from a specific file version is 

• http://mbmsrepairl . example. com/path/repair_script?fileURI= 
www.example.com/greatmusic/numberl. aac &Content-MD5= 
ODZi YTU 1 OTFkZG Y2NW Y5 ODh==&SBN= 1 2 

For messaging efficiency, the formal definition enables several contiguous and non-contiguous ranges to be expressed, 
as well as a number of symbols with ESIs of a given value or above in a single query: 

• An entire file (like in the above example). 

• A symbol of a source block (e.g. ...&SBN=12;ESI=23). 

• A range of symbols for a certain source block (e.g. ...&SBN=12;ESI=23-28). 

• A number of symbols with ESIs of a given value or above (e.g. . . .&SBN=12;ESI=120+10). 

• A hst of symbols for a certain source block (e.g. ...&SBN=12;ESI=23,26,28). 

• All symbols of a source block (e.g. ...&SBN=12). 



ETSI 



3GPP TS 26.346 version 6.10.0 Release 6 64 ETSI TS 126 346 V6.10.0 (2007-10) 

• All symbols of a range of source blocks (e.g. ...&SBN=12-19). 

• non-contiguous ranges (e.g.l. ...&SBN=12;ESI=34&SBN=20;ESI=23 also, 
e.g. 2. ...&SBN=12-19&SBN=28;ESI=23-59&SBN=30;ESI=101). 

9.3.7 File Repair Response Message 

Once the MBMS file repair server has assembled a set of encoding symbols that contain sufficient data to allow the UE 
to reconstruct the file data from a particular file repair request, the MBMS file repair server sends one message to the 
UE. Each file repair response occurs in the same TCP and HTTP session as the repair request that initiated it. 

An MBMS client shall be prepared for any of these 4 response scenarios: 

• The server returns a repair response message where a set of encoding symbols forms an HTTP payload as 
specified below. 

• The server redirects the client to a broadcast/multicast delivery (an MBMS download session). 

• The server redirects the client to another file repair server (if a server is functioning correctly but is temporarily 
overloaded). 

• An HTTP error code is returned (note that sub-clause 9.3.8 describes the case of no server response). 

For (reasonably) uniformly distributed random data losses, immediate point-to-point HTTP delivery of the repair data 
will generally be suitable for all clients. However, broadcast/multicast delivery of the requested data may be desirable in 
some cases: 



• 



• 



A repeat MBMS download (all or part of the files from a download session) is already scheduled and the BM-SC 
prefers to handle repairs after that repeat MBMS download. 

Many UEs request download data (over a short period of time) indicating that broadcast/multicast delivery of the 
repaired data would be desirable. 



In this case a redirect to the broadcast/multicast repair session for UEs that have made a repair request would be 
advantageous. 

9.3.7.1 File Repair Response Messages Codes 

In the case that the file repair server receives a correctly formatted repair request which it is able to understand and 
properly respond to with the appropriate repair data, the file repair server shall attempt to serve that request without an 
error case. 

For a direct point-to-point HTTP response with the requested data, the file response message shall report a 200 OK 
status code and the file repair response message shall consist of HTTP header and file repair response payload (HTTP 
payload), as defined in sub-clause 9.3.7.2. If the client receives a 200 OK response with fewer than all the quantity of 
requested symbols it shall assume that the file repair server wishes the missing symbols to be requested again (due to its 
choice or inability to deliver those symbols with this HTTP response). 

For a redirect case the file repair server uses the HTTP response status code 302 (Found - Redirection) to indicate to the 
UE that the resource (file repair data) is temporarily available via a different URL The temporary URI is given by the 
Location field in the HTTP response. In the case of a redirect to another file repair server, this temporary URI shall be 
the URL of that repair server. 

In the case of a redirect to a broadcast/multicast delivery, the temporary URI shall be the URI of the Session 
Description (SDP file) of the broadcast/multicast (repair) session as described in sub-clause 9. 3. 5. 3. Other HTTP status 
codes (RFC 2616 [18]) shall be used to support other cases. Other cases may include server errors, client errors (in the 
file repair request message) and server overload. 

In case the file repair server does not find the requested file (file with given fileURI is found), the server shall respond 
with '400 Bad Request' and optionally with '0001 File not found' in the response body. As a result, the MBMS UE may 
choose another file repair server as defined in clause 9.3.5. 

In case the file repair server does not find the requested version of the requested file (file with given fileURI is found 
but Content-MD5 is not found), the server shall respond with '400 Bad Request' and optionally with '0002 Content- 
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MD5 not valid' in the response body. As a result, the MBMS UE may chose another file repair server as defined in 
clause 9.3.5. Or the MBMS UE may request the latest version of the file and discard the previously received chunks of 
the file. Note, the MBMS UE can request the latest version of a file by using only the fileURI argument in the file repair 
request. 

Note. In case of repetitive server errors, the client is not expected to go through the complete list of available file 
repair servers, and may abandon after a limited number of attempts. 

In case the file repair server does not find any of the requested SBN or ESI values, it shall respond with the '400 Bad 
Request' and optionally with '0003 SBN or ESI out of range' in the response body. As a result, the UE should discard all 
received chunks of the file and request the entire file from the file repair server. 

In case the file repair server receives unknown query line arguments, it shall respond with '501 Not Implemented'. The 
server should add the HTTPl.l 'Server' header with the value 'MBMS/6'. As a result, the client should try to fetch the 
entire file from the file repair server. Note, this behaviour is intended to make the file repair service forward compatible 
and allow addition of new function in later releases. 

HTTP response error messages may contain a message body, which gives a more detailed error message. The MIME 
type of such message body shall be in text/plain. The syntax of the HTTP error message body is defined in ABNF [23] 
as follows: 

http-error-body = error-code (SP / HTAB) error-description CRLF 

error-code = 4DIGIT 

error-description = 1*(SP / VCHAR) 

Note that the following error messages MAY be used in the message body of the HTTP response error messages. 

0001 File not found 

0002 Content-MD5 not valid 

0003 SBN or ESI out of range 

9.3.7.2 File Repair Response Message Format for HTTP Carriage of Repair Data 

The file repair response message consists of HTTP header and file repair response payload (HTTP payload). 
The HTTP header shall provide: 

• HTTP status code, set to 200 OK. 

• Content type of the HTTP payload (see below). 

• Content transfer encoding, set to binary. 

The Content-Type shall be set to "application/simpleSymbolContainer", which denotes that the message body is a 
simple container of encoding symbols as described below. 

This header is as follows: 

• HTTP/1.1 200 OK 

• Content-Type: application/simpleSymbolContainer 

• Content-Transfer-Encoding: binary 

NOTE: Other HTTP headers (RFC 2616 [18]) may also be used but are not mandated by this mechanism. 

Encoding symbols are included in the response in groups. Each group is preceded by an indication of the number of 
symbols within the group and an EEC Payload ID coded according to the FEC scheme used for the original file delivery 
session. The FEC Payload ID identifies all the symbols in the group in the same way that the FEC Payload ID of an 
FEC source or repair packet identifies all the symbols in the packet. The file repair response payload is constructed by 
including each FEC Payload ID and Encoding Symbol group one after another (these are already byte aligned). The 
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order of these pairs in the repair response payload may be in order of increasing SBN, and then increasing ESI, value; 
however no particular order is mandated. 

A single HTTP repair response message shall contain, at the most, the same number of symbols as requested by the 
respective HTTP repair request message. 

The UE and file repair server already have sufficient information to calculate the length of each encoding symbol and 
each EEC Payload ID. All encoding symbols are the same length; with the possible exception of the last source 
encoding symbol in the repair response. All EEC Payload IDs are the same length for one file repair request-response as 
a single EEC Scheme is used for a single file. 

Figure 17: deleted 

Eigure 18 illustrates the complete file repair response message format (box sizes are not indicative of the relative 
lengths of the labelled entities). 
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Length Indicator (2 bytes): indicates the number of encoding symbols in the group (in network byte order, i.e. high 

order byte first) 
FEC Payload ID: indicates which encoding symbols are included in the group. The format and interpretation of the 

FEC Payload ID are dependent on the FEC Scheme in use. 
Encoding Symbols: contain the encoding symbols. All the symbols shall be the same length. 



9.3.7.3 



Figure 18: File Repair Response Message Format 



File Repair Response for Broadcast/IVIulticast of Repair Data 



Details of how a file repair server decides, or is instructed, to use broadcast/multicast repair instead of point-to-point 
over HTTP are implementation specific and beyond the scope of the present document. 

Prior to the decision to use broadcast/multicast repair, each repair response shall be provided by HTTP according to 
sub-clause 9.3.7.2. 

The file repair server uses the HTTP response status code 302 (Found - Redirection) to indicate to the UE that the 
resource (file repair data) is temporarily available via a different URL The temporary URI is given by the Location field 
in the HTTP response and is the URI of the Session Description (SDP file) of the broadcast/multicast repair session. 

Where feasible, it is recommended that the same download session that delivered the original data be used for the 
broadcast/multicast repair. If this conflicts with the session end time limit of the Session Description then a new version 
of the Session Description shall be sent with an updated (extended) session end time. This shall be sent in-band of that 
download session. 

In some cases this may not be feasible and a different (possibly new) download session may be defined for the repair. 
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The SDP file for broadcast/multicast repair session may be carried as payload (entity-body) in the HTTP response - 
which is especially useful if the broadcast/multicast repair session is a new (or recently end time modified) FLUTE 
download session and other means of service announcement prior to this were not feasible. 

The delivery method's associatedDeliveryProcedureDescription may be updated and the new version transmitted in- 
band with the download session so that currently active client back-off timers are reset, thus minimizing additional 
client requests until after the broadcast/multicast repair session. The server shall be prepared for additional requests in 
any case as successful reception of the updated associatedDeliveryProcedureDescription can not be assured in all cases. 

The existence of a broadcast/multicast file repair session is signalled by the inclusion of the optional bmFileRepair 
procedure in the updated Associated Delivery procedure description. This is signalled by the bmFileRepair element 
with a single "sessionDescriptionURI" attribute of type "xs:anyURI" which specifies the URI of the broadcast/multicast 
file repair session's session description. 

In the cases where the same IP addressing is used for the broadcast/multicast repair session as the original download 
session, the UE simply shall not leave the group. Otherwise, the UE shall join to the MBMS bearer for the repair 
session as it would for any MBMS session. 

A broadcast/multicast file repair session behaves just as an MBMS download session, and the determination of end of 
files and session, and use of further associated delivery procedures uses the same techniques as specified for the MBMS 
download delivery method. 



9.3.8 Server Not Responding Error Case 



In the error case where a UE determines that the its selected file repair server is not responding it shall return to the 
serverURI list of repair servers and uniformly randomly select another server from the list, excluding any servers it has 
determined are not responding. All the repair requests message(s) from that UE shall then be immediately sent to the 
newly selected file repair server. 

If all of the repair servers from the serverURI list are determined to be not responding, the UE may attempt an HTTP 
GET to retrieve a, potentially new, instance of the session's Associated Procedure Description; otherwise UE behaviour 
in this case is unspecified. 

A UE determines that a file repair server is not responding if any of these conditions apply: 

1 . The UE is unable to establish a TCP connection to the server. 

2. The server does not respond to any of the HTTP repair requests that have been sent by the UE (it is possible that 
second and subsequent repair requests are sent before the first repair request is determined to be 
not-responded-to) . 

3. The server returns an unrecognized message (not a recognizable HTTP response). 

4. The server returns an HTTP server error status code (in the range 500 to 505). 

9.4 The Reception Reporting Procedure 

Following successful reception of content whether through point- to -multipoint MBMS bearers only or using both point- 
to-multipoint and point-to-point bearers, a reception reporting procedure can be initiated by the MBMS Receiver (UE) 
to the BM-SC. 

For MBMS Download Delivery method, the reception reporting procedure is used to report the complete reception of 
one or more files. For MBMS Streaming Delivery method, the reception reporting procedure is used to report statistics 
on the stream. 

If the BM-SC provided parameters requiring reception reporting confirmation then the MBMS Receiver shall confirm 
the content reception. 

If reception reporting is requested for statistical purposes the BM-SC may specify the percentage subset of MBMS 
receivers it would like to perform reception reporting. 

Transport errors can prevent an MBMS Receiver from deterministically discovering whether the reception reporting 
associated delivery procedure is described for a session, and even if this is successful whether a sample percentage is 
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described. An MBMS Receiver shall behave according to the information it has even when it is aware that this may be 
incomplete. 

The MBMS Receiver: 

1. Identifies the complete reception of a content item (e.g. a file). See sub-clauses 9.4. land 9.4.2. 

2. Determines the need to report reception. See sub-clause 9.4.3. 

3. Selects a time (Request time) at which a reception report request will be sent and selects a server from a list - 
both randomly and uniformly distributed. See sub-clauses 9.4.4 and 9.4.5. 

4. Sends a reception report request message to the selected server at the selected time. See sub-clause 9.4.6. 

Then the server: 

1. Responds with a reception report response message either describing a success or an error case. See sub-clause 
9.4.7. 

9.4.1 Identifying Complete File Reception from MBMS Download 

A file is determined to be completely downloaded when it is fully received and reconstructed by MBMS reception with 
FEC decoding (if FEC is actually used) and/or a subsequent File Repair Procedure (sub-clause 9.3). The purpose of 
determining file download completeness is to determine when it is feasible for a UE to compile the RAck reception 
report for that file. 

9.4.2 Identifying Complete MBMS Delivery Session Reception 

Delivery sessions (download and streaming) are considered complete when the "time to" value of the session 
description (from "t=" in SDP) is reached. Where the end time is unbounded (time to = 0) then this parameter is not 
used for identifying completed sessions. 

Delivery sessions are also considered complete when the UE decides to exit the session - where no further data from 
that session will be received. In this case the UE may or may not deactivate the MBMS bearer(s). 

For MBMS download sessions, FLUTE provides a "Close session flag" (see sub-clause 7.2.7) which, when used, 
indicates to the UE that the session is complete. 

9.4.3 Determining Whether a Reception Report Is Required 

Upon full reception of a content item or when a session is complete, the MBMS Receiver must determine whether a 
reception report is required. An Associated Delivery Procedure Description indicates the parameters of a reception 
reporting procedure (which is transported using the same methods as the ones that describe File Repair). 

A delivery method may associate zero or one associated delivery procedure descriptions with an MBMS delivery 
session. Where an associated delivery procedure description is associated with a session, and the description includes a 
postReceptionReport element, the UE shall initiate a reception reporting procedure. Reception reporting behaviour 
depends on the parameters given in the description as explained below. 

The Reception Reporting Procedure is initiated if: 

a. A postReceptionReport element is present in the associated procedure description instance. 
One of the following will determine the UE behaviour: 

b. reportType is set to RAck (Reception Acknowledgement). Only successful file reception is reported without 
reception details. 

c. reportType is set to StaR (Statistical Reporting for successful reception). Successful file reception is reported (as 
with RAck) with reception details for statistical analysis in the network. 

d. reportType is set to StaR-all (Statistical Reporting for all content reception). The same as StaR with the addition 
that failed reception is also reported. StaR-all is relevant to both streaming and download delivery. 
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The reportType attribute is optional and behaviour shall default to RAck when it is not present. 

The samplePercentage attribute can be used to set a percentage sample of receivers which should report reception. This 
can be useful for statistical data analysis of large populations while increasing scalability due to reduced total uplink 
signalling. The samplePercentage takes on a value between and 100, including the use of decimals. It is 
recommended that no more than 3 digits follow a decimal point (e.g. 67.323 is sufficient precision). 

The samplePercentage attribute is optional and behaviour shall default to 100 (%) when it is not present. The 
samplePercentage attribute may be used with StaR and StaR-all, but shall not be used with RAck. 

When the samplePercentage is not present or its value is 100 each UE which entered the associated session shall send a 
reception report. If the samplePercentage were provided for reportType StaR and StaR-all and the value is less than 
100, the UE generates a random number which is uniformly distributed in the range of to 100. The UE sends the 
reception report when the generated random number is of a lower value than the samplePercentage value. 

9.4.4 Request Time Selection 

The MB MS receiver selects a time at which it is to issue a delivery confirmation request. 

Back-off timing is used to spread the load of delivery confirmation requests and responses over time. 

Back-off timing is performed according to the procedure described in sub-clause 9.3.4. The ojfsetTime and 
randomTime Period used for delivery confirmation may have different values from those used for file-repair and are 
signalled separately in the reception reporting description of the associated delivery procedure description instance. 

In general, reception reporting procedures may be less time critical than file repair procedures. Thus, if a postFileRepair 
timer may expire earlier than a postReceptionReport, radio and signalling resources may be saved by using the file 
repair point-to-point PDP context (and radio bearer) activate period also for reception reporting (to remove the delay 
and signalling of multiple activations and deactivations over time) 

The default behaviour is that a UE shall stop its postReceptionReport timers which are active when a postFileRepair 
timer expires, which results in the successful initiation of point-to-point communications between UE and BM-SC. 

In some circumstances, the system bottleneck may be in the server handling of reception reporting. In this case the 
forceTimelndependence attribute may be used and set to true, (false is the default case and would be a redundant use of 
this optional attribute), ^htn forceTimelndependence is true the UE shall not use file repair point-to-point connections 
to send reception reporting messages. Instead it will allow the timers to expire and initiate point-to-point connections 
dedicated to reception report messaging. 

For StaR and StaR-all, session completeness - according to sub-clause 9.4.2 - shall determine the back-off timer 
initialization time. 

For RAck, the complete download session - according to sub-clause 9.4.1 - as well as completing any associated file 
repair delivery procedure shall determine the back-off timer initialization time. RAcks shall be only sent for completely 
received files. 

9.4.5 Reception Report Server Selection 

Reception report server selection is performed according to the procedure described in sub-clause 9.3.5.2. 

9.4.6 Reception Report Message 

Once the need for reception reporting has been established, the MBMS receiver sends one or more Reception Report 
messages to the BM-SC. All Reception Report requests and responses for a particular MBMS transmission should take 
place in a single TCP session using the HTTP protocol (RFC 2616 [18]). 

The Reception Report request shall include the URI of the file for which delivery is being confirmed. URI is required to 
uniquely identify the file (resource). 

The client shall make a Reception Report request using the HTTP (RFC 2616 [18]) POST request carrying XML 
formatted metadata for each reported received content (file). An HTTP session shall be used to confirm the successful 
delivery of a single file. If more than one file were downloaded in a particular MBMS download multiple reception 
reports shall be added in a single POST request. 
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Each Reception Report is formatted in XML according the following XML schema (sub-clause 9.5.3). An informative 
example of a single reception report XML object is also given (sub-clause 9.5.3.2). 

Multipart MIME (multipart/mixed) may be used to aggregate several small XML files of reception reports to a larger 
object. 

For Reception Acknowledgement (RAck) a receptionAcknowledgement element shall provide the relevant data. 

For Statistical Reporting (StaR) a statisticalReporting element shall provide the relevant data. 

For both RAck and StaR/StaR-all (mandatory): 

• For download, one or more fileURI elements shall specify the list of files which are reported. If the Content- 
MD5 value of the file is present in the FDT, it shall be provided in the Content-MD5 attribute in the reception 
report. Note, this allows unambigous identification of the files. 

For only StaR/StaR-all (all optional): 

• Esich fileURI element has an optional receptionSuccess status code attribute which defaults to "true" ("1") when 
not used. This attribute shall be used for StaR-all reports. This attribute shall not be used for StaR reports. 

• Each QoE Metrics element has eleven attributes as defined in sub-clause 9.5.3 that correspond to the QoE 
metrics listed in sub-clause 8.4.2. Individual metrics, both at session and at media level can be selected via SDP 
as described in sub-clause 8.3.2.1. 

• The sessionID attribute identifies the delivery session. This is of the format source_IP_address + ":" + 
FLUTE_TSI/RTP_source_port. 

• The sessionType attribute defines the basic delivery method session type used = "download" II "streaming" II 
"mixed". 

• The serviceld attribute value and format is taken from the respective userServiceDescription servicelD 
definition. 

• The clientld attribute is unique identifier for the receiver, e.g. an MSISDN of the UE as defined in [77]. 

The serviceURI attribute value and format is taken from the respective associatedDeliveryProcedureDescription 
serviceURI, which was selected by the UE for the current report. This attribute expresses the reception report server to 
which the reception report is addressed. 

9.4.7 Reception Report Response Message 

An HTTP response is used as the Reception Report response message. 

The HTTP header shall use a status code of 200 OK to signal successful processing of a Reception Report. Other status 
codes may be used in error cases as defined in RFC 2616 [18]. 

9.5 XML-Schema for Associated Delivery Procedures 
9.5.1 Generic Associated Delivery Procedure Description 

Below is the formal XML syntax of associated delivery procedure description instances. Documents following this 
schema can be identifed with the MIME type "application/mbms-associated-procedure-description+xml" defined in 
Annex C.7. 

<?xml version="l . 0" encoding="UTF-8" ?> 
<xs : schema 

xmlns="urn: 3gpp : metadata : 2 05 :MBMS : associatedProcedure" 

xmlns:xs="http://www.w3 . org/2 l/XMLSchema" 

targetNamespace="urn: 3gpp rmetadata : 2005 :MBMS : associatedProcedure" 

elementFormDefault= "qualified" > 

<xs : element name="associatedProcedureDescription" type="associatedProcedureType"/> 

<xs : complexType name="associatedProcedureType" > 
<xs : sequence> 
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<xs:element name="postFileRepair" type="basicProcedureType" minOccurs="0"/> 
<xs:element name="bmFileRepair" type="bmFileRepairType" minOccurs="0"/> 
<xs:element name="postReceptionReport " type=" report ProcedureType" minOccurs="0"/> 
<xs:any namespace="##other" processContents="skip" minOccurs=" 0" maxOccurs= "unbounded" /> 
</xs : sequence> 
</xs : complexType> 

<xs : complexType name="basicProcedureType" > 
<xs : sequence> 

<xs: element name="serviceURI" type="xs : anyURI" maxOccurs=" unbounded" /> 
</xs : sequence> 

<xs : attribute name="of f setTime" type="xs runsignedLong" use="optional"/> 
<xs : attribute name="randomTimePeriod" type="xs runsignedLong" use=" required" /> 
</xs : complexType > 
<xs : complexType name="bmFileRepairType" > 

<xs : attribute name="sessionDescriptionURI" type="xs : anyURI" use=" required" /> 
</xs : complexType > 

<xs : complexType name= "report ProcedureType " > 
<xs : complexContent> 

<xs : extension base="basicProcedureType" > 

<xs : attribute name="samplePercentage" type="xs : decimal" use=" optional" 

default="100"/> 
<xs : attribute name="f orceTimelndependence" type="xs : boolean" use=" optional" 

default="false"/> 
<xs : attribute name="reportType" type="xs : string" use="optional"/> 
</xs : extension> 
</xs : complexContent> 
</xs : complexType > 
</xs : schema> 

"reportType" value = "rack" | | "star" | | "star-all" 

9.5.2 Example Associated Delivery Procedure Description Instance 

Below is an example of an associated delivery procedure description for reception reporting. 

<?xml version="l . 0" encoding="UTF-8" ?> 
<associatedProcedureDescription 

xmlns="urn: 3gpp : metadata : 2 05 :MBMS : associatedProcedure" 
xmlns :xsi="http : //www. w3 . org/2001/XMLSchema-instance" > 
<postFileRepair 

of f setTime="5" 
randomTimePeriod= " 1 " > 
<serviceURI>http: //mbmsrepairO .example . com/path/repair_script "</serviceURI> 
<serviceURI>http: //mbmsrepairl .example . com/pathl/repair_script "</serviceURI> 
<serviceURI>http: //mbmsrepair2 .example . com/path2/repair_script "</serviceURI> 
</postFileRepair> 

<bmFileRepair sessionDescriptionURI="http : //www. example . com/3gpp/mbms/sessionl . sdp"/> 
<postReceptionReport 

offsetTime="5" 
randomTimePeriod= "10" 
reportType= " star-all " 
samplePercentage= "10 0" 
f orceTimeIndependence= " " > 
<serviceURI>"http: //mbmsreport .example . com/path/report_script "</serviceURI> 
</postReceptionReport> 
</associatedProcedureDescription> 

9.5.3 XML Syntax for a Reception Report Request 

Below is the formal XML syntax of reception report request instances. 

<?xml version="l . 0" encoding="UTF-8" ?> 

<xs : schema xmlns :xs="http : //www. w3 . org/2 OOl/XMLSchema" 
targetNamespace="urn: 3gpp : metadata : 2 05 :MBMS : receptionreport" 
xmlns="urn: 3gpp : metadata : 2 05 :MBMS : receptionreport" 
elementFormDefault= "qualified" > 

<xs : element name="receptionReport " type="receptionReportType"/> 
<xs : complexType name="receptionReportType" > 
<xs : choice> 

<xs : element name="receptionAcknowledgement " type="rackType"/> 
<xs: element name="statisticalReport " type="starType"/> 

<xs:any namespace="##other" processContents="skip" minOccurs="0" maxOccurs= "unbounded" /> 
</xs : choice> 
</xs : complexType > 
<xs : complexType name= " rackType " > 
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<xs : sequence> 

<xs: element name="f ileURI" type="xs : anyURI" 
minOccurs="0" maxOccurs= "unbounded" > 
<xs : complexType> 

<xs rattribute name=" Content -MD5" type="xs :base64Binary" use="optional"/> 
<xs ranyAttribute processContents="skip"/> 
</xs : complexType> 
</xs : element> 
</xs : sequence> 
</xs : complexType> 
<xs : complexType name= " starType " > 
<xs : sequence> 

<xs:element name="f ileURI" type="f ileUriType" minOccurs="0" maxOccurs=" unbounded" /> 
<xs: element name="qoeMetrics" type="qoeMetricsType" minOccurs=" 0" maxOccurs="l"/> 
<xs:any namespace="##other" processContents="skip" minOccurs=" 0" maxOccurs= "unbounded" /> 
</xs : sequence> 

<xs rattribute name="sessionId" type="xs : string" use="optional"/> 
<xs rattribute name="sessionType" type="sessionTypeType" use="optional"/> 
<xs rattribute name="serviceld" type="xs r string" use= "optional "/> 
<xs rattribute name="clientld" type="xs r string" use="optional"/> 
<xs rattribute name="serverURI" type="xs r anyURI" use="optional"/> 
<xs r anyAttribute processContents="skip"/> 
</xs r complexType > 

<xs r simpleType name="sessionTypeType" > 
<xs r restriction base="xs r string" > 

<xs r enumeration value= "download" /> 
<xs r enumeration value=" streaming" /> 
<xs r enumeration value= "mixed" /> 
</xs r restriction> 
</xs r simpleType > 

<xs r complexType name="f ileUriType" > 
<xs r simpleContent> 

<xs r extension base= "xs r anyURI " > 

<xs rattribute name="receptionSuccess" type="xs r boolean" use="optional" def ault="true"/> 
</xs r extension> 
</xs r simpleContent> 

<xs rattribute name=" Content -MD5" type="xs rbase64Binary" use="optional"/> 
<xs ranyAttribute processContents="skip"/> 
</xs r complexType > 

<xs r complexType name="qoeMetricsType" > 
<xs r sequence> 

<xsrany namespace="##other" processContents="skip" minOccurs=" 0" maxOccurs= "unbounded" /> 
</xs r sequence> 

<xs rattribute name="totalCorruptionDuration" type="xs runsignedLong" use= "optional "/> 
<xs rattribute name="numberOf CorruptionEvents" type="xs runsignedLong" use="optional"/> 
<xs rattribute name="t" type="xs r boolean" use= "optional "/> 

<xs rattribute name="totalRebuf f eringDuration" type="xs r double" use="optional"/> 
<xs rattribute name="numberOfRebuf f eringEvents" type="xs runsignedLong" use= "optional "/> 
<xs rattribute name="initialBuff eringDuration" type="xs r double" use="optional"/> 
<xs rattribute name="totalNumberof SuccessivePacketLoss" type="xs runsignedLong" 

use= " optional " / > 
<xs r attribute name="numberOf SuccessiveLossEvents" type="xs runsignedLong" use="optional"/> 
<xs rattribute name="f ramerateDeviation" type="xs r double" use="optional"/> 
<xs rattribute name="totalJitterDuration" type="xs r double" use="optional"/> 
<xs rattribute name="numberOf JitterEvents" type="xs runsignedLong" use="optional"/> 
<xs ranyAttribute processContents="skip"/> 
</xs r complexType > 
</xs r schema> 

9.5.3.1 Use of Specific Values 

Void 

9.5.3.2 Example XML for the Reception Report Request 

<?xml version="l . 0" encoding="UTF-8" ?> 

<receptionReport xmlns="urnr 3gpp r metadata r 2 05 rMBMS r receptionreport" 
xmlns rxsi="http r //www. w3 . org/2001/XMLSchema-instance" > 
<receptionAcknowledgement> 

<f ileURI>"http r //www. example . com/mbms-f iles/f ilel . 3gp"</f ileURI> 
<f ileURI>"http r //www. example . com/mbms-f iles/f ile2 . 3gp"</f ileURI> 
<f ileURI>"http r //www. example . com/mbms-f iles/f ile4 . 3gp"</f ileURI> 
< /recept ionAcknowledgement > 
< /recept ionReport > 
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A second example shows a statistical report for a mixed session. 

<?xml version="l . 0" encoding="UTF-8" ?> 

<receptionReport xmlns="urn: 3gpp : metadata : 2 05 :MBMS : receptionreport " 
xmlns :xsi="http: //www. w3 . org/2 l/XMLSchema- instance" 

xsi : schemaLocation="urn: 3gpp : metadata : 2 05 :MBMS : receptionreport receptionreport .xsd"> 
<statisticalReport 

clientld=" client ID" 

sessionType= "mixed" 

serverURI="bmsc . example . com" 

sessionId="sessionID" 

serviceld= " servicelD" > 

<f ileURI receptionSuccess=" false ">"http: //www. example . com/mbms - files/ file 1 . 3gp"</f ileURI> 

<f ileURI>"http : //www. example . com/mbms-f iles/f ile2 . 3gp"</f ileURI> 

<f ileURI>"http : //www. example . com/mbms-f iles/f ile4 . 3gp"</f ileURI> 

<qoeMetrics 

f ramerateDeviation="0 . 345" 
t="false" 

numberOf SuccessiveLossEvents= " 5 " 
numberOf CorruptionEvents= " 6 " 
numberOf Rebuff eringEvents= " " 
initialBuf feringDuration="3 .213" 
numberOf JitterEvents= " " 
totalCorruptionDuration="2 52 0" 
totalNumberof Success ivePacket Loss = " 25 " / > 
</statisticalReport> 
</receptionReport> 
A second example shows a statistical report for a mixed session. 

<?xml version="l . 0" encoding="UTF-8" ?> 

<receptionReport xmlns="urn: 3gpp : metadata : 2 05 :MBMS : receptionreport" 
xmlns :xsi="http : //www. w3 . org/2001/XMLSchema-instance" 

xsi : schemaLocation="urn: 3gpp rmetadata : 2005 :MBMS : receptionreport receptionreport .xsd" > 
<statisticalReport 

clientld=" client ID" 

sessionType= "mixed" 

serverURI="bmsc .example . com" 

sessionId="sessionID" 

serviceld=" servicelD" > 

<f ileURI receptionSuccess=" false ">"http: //www. example . com/mbms-f iles/f ilel . 3gp"</f ileURI> 

<f ileURI>"http : //www. example . com/mbms-f iles/f ile2 . 3gp"</f ileURI> 

<f ileURI>"http : //www. example . com/mbms-f iles/f ile4 . 3gp"</f ileURI> 

<qoeMetrics 

f ramerateDeviation="0 . 345" 

t="false" 

numberOf SuccessiveLossEvents= " 5 " 

numberOf CorruptionEvents= " 6 " 

numberOf Rebuff eringEvents= " " 

initialBuf feringDuration=" 3 .213" 

numberOf JitterEvents= " " 

totalCorruptionDuration="2 52 0" 

totalNumberof Success ivePacketLoss=" 25" /> 
</statisticalReport> 
< /recept ionReport > 



1 Media codecs and formats 
10.1 General 

The set of media decoders that are supported by the MB MS Client to support a particular media type are defined below. 
Speech, Audio, Video and Timed Text media decoders are relevant for both MB MS Download and Streaming delivery. 
Other media decoders are only relevant for MB MS Download delivery. 



10.2 Speech 



If speech is supported, the AMR decoder shall be supported for narrow-band speech 3GPP TS 26.071 [48], 3GPP TS 
26.090 [49], 3GPP TS 26.073 [50] and 3GPP TS 26.107 [51]. The AMR wideband speech decoder, 3GPP TS 26.171 
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[52], 3GPP TS 26.190 [53], 3GPP TS 26.173 [54] and 3GPP TS 26.204 [55], shall be supported when wideband speech 
working at 16 kHz sampHng frequency is supported. 

10.3 Audio 

If audio is supported, then the following two audio decoders should be supported: 

• Enhanced aacPlus 3GPP TS 26.401 [28], 3GPP TS 26.410 [29] and 3GPP TS 26.41 1 [30]. 

• Extended AMR-WB 3GPP TS 26.290 [24], 3GPP TS 26.304 [25] and 3GPP TS 26.273 [26]. 

Specifically, based on the audio codec selection test results. Extended AMR-WB is strong for the scenarios marked with 
blue. Enhanced aacPlus is strong for the scenarios marked with orange, and both are strong for the scenarios marked 
with green colour in table 1 . 

Table 1 



Content type 
Bit rate 


Music 


Speech over IVIusic 


Speecli between IVIusic 


Speech 


14 kbps mono 










1 8 kbps stereo 










24 kbps stereo 










24 kbps mono 










32 kbps stereo 










48 kbps stereo 








i 



More recent information on the performance of the codecs based on more recent versions of the codecs can be found in 
TR 26.936 [86]. 



10.4 Synthetic audio 



If synthetic audio is supported, the Scalable Polyphony MIDI (SP-MIDI) content format defined in Scalable Polyphony 
MIDI Specification [56] and the device requirements defined in Scalable Polyphony MIDI Device 5-to-24 Note Profile 
for 3GPP [57] should be supported. 

SP-MIDI content is delivered in the structure specified in Standard MIDI Files 1.0 [58], either in format or format 1. 

In addition the Mobile DLS instrument format defined in [59] and the Mobile XMF content format defined in [60] 
should be supported. 

A PSS client supporting Mobile DLS shall meet the minimum device requirements defined in [59] in section 1.3 and the 
requirements for the common part of the synthesizer voice as defined in ISO/IEC 10646-1 [70] in section 1.2.1.2. If 
Mobile DLS is supported, wavetables encoded with the G.711 A-law codec (wFormatTag value 0x0006, as defined in 
[59]) shall also be supported. The optional group of processing blocks as defined in [59] may be supported. Mobile DLS 
resources are delivered either in the file format defined in ISO/IEC 10646-1 [70], or within Mobile XMF as defined in 
[60] . For Mobile DLS files delivered outside of Mobile XMF, the loading application should unload Mobile DLS 
instruments so that the sound bank required by the SP-MIDI profile [57] is not persistently altered by temporary 
loadings of Mobile DLS files. 

Content that pairs Mobile DLS and SP-MIDI resources is delivered in the structure specified in Mobile XMF [60]. As 
defined in [60], a Mobile XMF file shall contain one SP-MIDI SMF file and no more than one Mobile DLS file. PSS 
clients supporting Mobile XMF must not support any other resource types in the Mobile XMF file. Media handling 
behaviours for the SP-MIDI SMF and Mobile DLS resources contained within Mobile XMF are defined in [60] . 

10.5 Video 

If video is supported, H.264 (AVC) Baseline Profile Level lb decoder (ITU-T Recommendation H.264 [43] and 
ISO/IEC 14496-10/FDAMl: "AVC Fidelity Range Extensions" [44]) with constraint_setl_flag=l and without 
requirements on output timing conformance (annex C of ITU-T Recommendation H.264 [43]) should be supported. 
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Note that MBMS does not offer dynamic negotiation of media codecs. To ensure the maximum level of interoperability, 
H.264 (AVC) is the only video decoder recommended for MBMS. However, it is to be noted that ITU-T 
Recommendation H.263 profile level 45 decoder (ITU-T Recommendation H.263 [45] and H.263 annex X [46]) shall 
be supported for PSS (3GPP TS 26.234 [47]) and hence may be used for MBMS User Service. 

When H.264 (AVC) is in use in the MBMS streaming delivery method, it is recommended to transmit H.264 (AVC) 
parameter sets within the SDP description of a stream (using sprop-parameter-sets MIME/SDP parameter - ISO/IEC 
1 4496- 10/FD AMI: "AVC Fidelity Range Extensions" [44]), and it is not recommended to transmit parameter sets 
within the RTP stream. Moreover, it is not recommended to reuse any parameter set identifier value that appeared 
previously in the SDP description or in the RTP stream. However, if a sequence parameter set is taken into use or 
updated within the RTP stream, it shall be contained at least in each IDR access unit and each access unit including a 
recovery point SEI message in which the sequence parameter set is used in the decoding process. If a picture parameter 
set is taken into use or updated within the RTP stream, it shall be contained at the latest in the first such access unit in 
each entry sequence that uses the picture parameter set in the decoding process, in which an entry sequence is defined as 
the access units between an IDR access unit or an access unit containing a recovery point SEI message, inclusive, and 
the next access unit, exclusive, in decoding order, which is either an IDR access unit or contains a recovery point SEI 
message. 

There are no requirements on output timing conformance (annex C of ITU-T Recommendation H.264 [43]) for MBMS 
clients. 

The H.264 (AVC) decoder in an MBMS client shall start decoding immediately when it receives data (even if the 
stream does not start with an IDR access unit) or alternatively no later than it receives the next IDR access unit or the 
next recovery point SEI message, whichever is earlier in decoding order. Note that when the interleaved packetization 
mode of H.264 (AVC) is in use, de-interleaving is done normally before starting the decoding process. The decoding 
process for a stream not starting with an IDR access unit shall be the same as for a valid H.264 (AVC) bitstream. 
However, the client shall be aware that such a stream may contain references to pictures not available in the decoded 
picture buffer. 



10.6 Still images 



If still images are supported, ISO/IEC JPEG [61] together with JFIF [62] decoders shall be supported. The support for 
ISO/IEC JPEG only applies to the following two modes: 

• baseline DCT, non-differential, Huffman coding, as defined in table B.l, symbol 'SOFO' in 
3GPPTS 26.273 [26]; 



• 



progressive DCT, non-differential, Huffman coding, as defined in table B.l, symbol 'S0F2' 
3GPPTS 26.273 [26]. 



10.7 Bitmap graphics 

If bitmap graphics is supported, the following bitmap graphics decoders should be supported: 

• GIF87a, [63]; 

• GIF89a, [64]; 

• PNG, [65]. 

10.8 Vector graphics 

If vector graphics is supported, SVG Tiny 1.2 [66], [67] and ECMAScript [68] shall be supported. 

NOTE 1: The compression format for SVG content is GZIP [42], in accordance with the SVG specification [66]. 

NOTE 2 Content creators of SVG Tiny 1.2 are strongly recommended to follow the content creation guidelines 
provided in annex L of 3GPP TS 26.234 [47]. 

NOTE 3: If SVG Tiny 1.2 will not be published within a reasonable timeframe, the decision to adopt SVG Tiny 1.2 
in favour of SVG Tiny 1 . 1 may be reconsidered. 
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10.9 Text 

The text decoder is intended to enable formatted text in a SMIL presentation. 
If text is supported, a MBMS client shall support 

• text formatted according to XHTML Mobile Profile [69]; 

• rendering a SMIL presentation where text is referenced with the SMIL 2.0 "text" element together with the 
SMIL 2.0 "src" attribute. 

If text is supported, the following character coding formats shall be supported: 

• UTF-8, [71]; 

• UCS-2, [70]. 

NOTE: Since both SMIL and XHTML are XML based languages it would be possible to define a SMIL plus 
XHTML profile. In contrast to the presently defined SMIL Language Profile that only contain SMIL 
modules, such a profile would also contain XHTML modules. No combined SMIL and XHTML profile is 
specified for MBMS. Rendering of such documents is out of the scope of the present document. 

10.10 Timed text 

If timed text is supported, MBMS clients shall support 3GPP TS 26.245 [72]. Timed text may be transported over RTP 
or downloaded contained in 3GP files using Basic profile. 

NOTE: When a MBMS client supports timed text it needs to be able to receive and parse 3GP files containing the 
text streams. This does not imply a requirement on MBMS clients to be able to render other continuous 
media types contained in 3GP files, e.g. AMR, if such media types are included in a presentation together 
with timed text. Audio and video are instead streamed to the client using RTP. 

10.11 3GPP file format 

An MBMS client shall support the Basic profile and the Extended presentation profile of the 3GPP file format 
3GPPTS 26.244 [32]. 

11 MBMS Metadata 

11.1 The MBMS Metadata Envelope 
11.1.1 Supported Metadata Syntaxes 

The MBMS metadata syntax supports the following set of features: 

• Support of carriage of SDP descriptions, and SDP is expected to sufficiently describe at least: MBMS Streaming 
sessions and, MBMS download sessions. 

• Support for multiple metadata syntaxes, such that the delivery and use of more than one metadata syntax is 
possible. 

• Consistency control of metadata versions, between senders and receivers, independent of the transport and bearer 
use for delivery. 

• Metadata fragments are identified, versioned and time-limited (expiry described) in a metadata fragment syntax- 
independent manner (which is a consequence of the previous two features). 
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1 1 .1 .2 Consistency Control and Syntax Independence 

The Metadata Envelope provides information to identify, version and expire metadata fragments. This is specified to be 
independent of metadata fragments syntax and of transport method (thus enabhng the use of more than one syntaxes 
and enable dehvery over more than a single transport and bearer). 

A metadata envelope may update the time validity of its metadata fragment without changing version if the metadata 
fragment itself has not changed. A newer version (higher version number) of a metadata envelope shall automatically 
expire the earlier version. If the content type (metadata fragment syntax) is recognized and valid, the UE shall use the 
new metadata fragment description. However, if the content type is not recognized or valid, the UE may maintain the 
expired version data until the newer version is correctly received. 

Service announcement senders shall increment the version by one for each subsequent transported version of a metadata 
fragment. However, a UE shall also accept versions with an increment greater than one (so that they do not fail in the 
case that an intermediate version was not successfully transported). 

1 1 .1 .3 Metadata Envelope Definition 

The attributes for a metadata envelope and their description is as follows. These attributes shall be supported: 

• metadataURL A URI providing a unique identifier for the metadata fragment. The metadataURI attribute shall 
be present. 

• version: The version number of the associated instance of the metadata fragment. The version number should be 
initialized to one. The version number shall be increased by one whenever the metadata fragment is updated. 
The version attribute shall be present. 

• validFrom: The date and time from which the metadata fragment file is valid. The validFrom attribute may or 
not be present. If not present, the UE should assume the metadata fragment version is valid immediately. 

• validUntil: The date and time when the metadata fragment file expires. The validUntil attribute may or not be 
present. If not present the UE should assume the associated metadata fragment is valid for all time, or until it 
receives a newer metadata envelope for the same metadata fragment describing a validUntil value. 

• contentType: The MIME type of the metadata fragment which shall be used as defined for "Content-Type" in 
RFC 2616 [18]. The contentType attribute shall be present for embedding metadata envelopes. The contentType 
attribute may be present for referencing metadata envelopes. 

The metadata envelope is instantiated using an XML structure. This XML contains a URI referencing the associated 
metadata fragment. The formal schema for the metadata envelope is defined as an XML Schema as follows. 

<?xml version="l . 0" encoding="UTF-8" ?> 

<xs : schema xmlns :xs="http : //www. w3 . org/2 OOl/XMLSchema" 

xmlns="urn: 3gpp : metadata : 2 05 :MBMS : envelope" 

elementFormDefault= "qualified" attributeFormDefault= "unqualified" 

targetNamespace="urn: 3gpp : metadata : 2 05 :MBMS : envelope "> 

<xs : element name="metadataEnvelope" type="metadataEnvelopeType"/> 
<xs : complexType name="metadataEnvelopeType" > 
<xs : sequence> 

<xs: element name="item" type="metadataEnvelopeItemType" maxOccurs= "unbounded" 
minOccurs= " 1 " / > 

</xs : sequence> 
</xs : complexType > 

<xs : complexType name="metadataEnvelopeItemType" > 
<xs : sequence> 

<xs: element name="metadataFragment " type="xs : string" minOccurs=" 0" maxOccurs="l"/> 
<xs:any namespace="##other" minOccurs=" 0" maxOccurs= "unbounded" processContents="lax"/> 
</xs : sequence> 

<xs : attribute name= "metadataURI" type="xs : anyURI" use=" required" /> 
<xs : attribute name= "version" type="xs rpositivelnteger" use=" required" /> 
<xs rattribute name= "validFrom" type="xs rdateTime" use="optional"/> 
<xs rattribute name= "validUntil" type="xs rdateTime" use="optional"/> 
<xs rattribute name=" contentType" type="xs r string" use="optional"/> 
<xs r anyAttribute processContents="skip"/> 
</xs r complexType > 
</xs r schema> 
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The metadataFragment element shall be encapsulated in the metadata envelope for embedded metadata fragments, and 
shall not be encapsulated where the metadata fragment is not embedded. In the embedded case, the metadataFragment 
element shall contain exactly one embedded metadata fragment as specified by the metadata envelope syntax and only 
one instance of the envelope element shall be used for encapsulating envelopes. 

An embedded metadata fragment (in the metadataFragment element) shall be escaped. Generally, an embedded 
metadata fragment should be escaped by placing inside a CD ATA section [31]. Everything starting after "<![CDATA[" 
string and ending at the "]]>" string would be ignored by the XML envelope parser (quotes not included). Thus, the 
embedded parts would appear as "<![CDATA[" + metadata_fragment + "]]>". In this case, the complete metadata 
envelope with embedded metadata fragment shall not violate the rules of CD AT A section usage [31]. 

In case the embedded metadata fragment is an XML document and include a CD ATA section , the embedded metadata 
fragment may be escaped by replacing illegal characters with their ampersand-escaped equivalents [31] (instead of 
encapsulating the whole fragment in a CD ATA section). For instance "<" is an illegal character that would be replaced 
by "<". This method is useful to avoid nesting CD ATA sections (which is not allowed). 

A metadata fragment which does not adhere to either of these two methods shall not be embedded in a metadata 
envelope, thus it may only be referenced from an referencing metadata envelope. 

Embedded fragments are not expected to be parsed by the metadata envelope XML parser, but decapsulated and passed 
to the relevant metadata management operation that is implementation specific (e.g. for immediate parsing, storage, 
etc.). 

1 1 .1 .4 Delivery of the Metadata Envelope 

An instance of metadata envelope shall be associated with an instance of a metadata fragment by one of two methods: 

• Embedded: The metadata fragment is embedded within the metadata envelope. 

• Referenced: The metadata fragment is referenced from the metadata envelope. 

The MBMS UE must know the MIME Type of each metadata fragment. 

In the embedded case, the envelope and fragment are, by definition, transported together and in-band of one another. In 
the referenced case, the envelope and fragment shall be transported together in-band of the same transport session. 

MBMS Service Announcement transports shall support delivery of the metadata envelope as a discrete object (XML 
document) for the referenced case. In the referenced case, the MIME type of the metadata fragment should be provided 
by the transport protocol (e.g. as a Content-Type text string). In both cases, the MIME type of the metadata envelope 
should be provided by the transport protocol. 

The Metadata Envelope includes a reference (metadataURI) to the associated metadata fragment using the same URI as 
the fragment file is identified by in the Service Announcement. Thus, Metadata Envelope can be mapped to its 
associated metadata fragment. 



1 1 .2 MBMS User Service Description Metadata Fragment 
1 1 .2.1 Definition of the MBMS User Service Bundle Description 

The root element of the MBMS User Service Bundle description is the bundleDescription element. The element is of 
the bundleDescriptionType. The bundleDescription contains one or several userServiceDescription elements and 
optionally a reference to the EEC repair stream description. 

Each userServiceDescription elcrnQnt shall have a unique identifier. The unique identifier shall be offered as serviceld 
attribute within the userServiceDescription element and shall be of URN format. 

The userServiceDescription tlQXWQXii may contain one or more name elements. The intention of a name element is to 
offer a title of the user service. For each name elements, the language shall be specified according to XML datatypes 
(XML Schema Part 2 [22]). 
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The userServiceDescriptionQltmQni may contain one or more serviceLanguage elements. Each serviceLanguage 
element represents the available languages of the user services. The language shall be specified according to XML 
datatypes (XML Schema Part 2 [22]). 

The userServiceDescription element may contain an accessPointName attribute. The accessPointName attribute is 
optional and gives an Access Point Name (APN) as defined in [77]. When this attribute is present, the MBMS UE shall 
use the given APN for MBMS UE to network interactions like File Repair and/or security registration. If this attribute is 
not present, the MBMS UE shall use a default PDP context for network interactions. 

Each userServiceDescription element shall contain at least one delivery Method element. The delivery Method element 
contains the description of one delivery method. The element shall contain one reference to a session description and 
may contain references to one associated delivery procedure and/or one service protection descriptions. The session 
description is further specified in sub-clause 5.2.2.2. 

The delivery Method element may contain a reference to an associated delivery procedure description. The description 
and configuration of associated delivery procedures is specified in sub-clause 5.2.2.3. 

The deliveryMethod element may contain a reference to a service protection description. The service protection 
description is specified in sub-clause 5.2.2.4. 

A userServiceDescription element contains zero or more accessGroup elements. An accessGroup element defines a list 
of access networks and is uniquely identified by its id attribute. An accessGroup element describes whether separate 
access systems for the same MBMS user service are used (see sub-clause 5.1.5.2 of [4]) by including one or more 
accessBearer elements, each describing one of those access systems and no two describing the same. Possible 
accessBearer values are '3GPP.R6.UTRAN' and '3GPP.R6.GERAN' which indicate transport by 3GPP release 6 
MBMS bearers according to specification [4]. For forward compatibility, other values are allowed but their definition 
and use are out of scope of this specification and a 3 GPP release 6 UE may silently ignore other values. 

A requiredCapabilities element gives a list of features, which are required for the consumption of the related MBMS 
user service. The list of features that are currently defined is included in section 11.9. The value of the feature element 
indicates the required feature. Note that the BM-SC can also determine the terminal capabilities from the terminal 
identification during the security registration. If the registering terminal does not have the required capabilities, the BM- 
SC can reject the security registration. 

Each deliveryMethod element contains zero or one accessGroupId attributes. One specific accessGroupId value maps to 
one specific accessGroup element id value. For each unique accessGroupId attribute value presented in a 
deliveryMethod element of a userServiceDescription instance, exactly one associated accessGroup element shall be 
present and the id attribute of the accessGroup element and the accessGroupId attribute shall have the same value. For 
each deliveryMethod element without an accessGroupId attribute, the UE should assume that the delivery method is 
offered through all available MBMS access systems. 

<?xml version="l . 0" encoding="UTF-8" ?> 

<xs : schema xmlns="urn: 3GPP rmetadata : 2005 :MBMS ruserServiceDescription" 
xmlns:xs="http://www.w3 . org/2 l/XMLSchema" 

targetNamespace="urn: 3GPP rmetadata : 2005 :MBMS ruserServiceDescription" elementFormDef ault="qualif ied" > 
<xs : element name= "bundleDescription" type= "bundleDescriptionType" /> 
<xs : complexType name="bundleDescriptionType" > 
<xs : sequence> 

<xs : element name= "userServiceDescription" type="userServiceDescriptionType" 
maxOccurs= " unbounded" / > 

<xs:any namespace="##other" minOccurs=" 0" maxOccurs= "unbounded" processContents="lax"/> 
</xs : sequence> 

<xs : attribute name="f ecDescriptionURI" type="xs : anyURI" use= "optional "/> 
<xs ranyAttribute processContents="skip"/> 
</xs : complexType > 

<xs : complexType name="userServiceDescriptionType" > 
<xs : sequence> 

<xs: element name="name" type="nameType" minOccurs=" 0" maxOccurs= "unbounded" /> 
<xs: element name=" serviceLanguage" type="xs : language" minOccurs=" 0" 
maxOccurs= " unbounded " / > 

<xs: element name=" requiredCapabilities" type=" requirement sType" minOccurs=" 0" 
maxOccurs= " 1 " / > 

<xs: element name= "deliveryMethod" type="deliveryMethodType" maxOccurs= "unbounded" /> 
<xs: element name=" accessGroup" type="accessGroupType" minOccurs=" 0" 
maxOccurs= " unbounded " / > 

<xs:any namespace="##other" minOccurs=" 0" maxOccurs= "unbounded" processContents="lax"/> 
</xs : sequence> 

<xs : attribute name="serviceld" type="xs : anyURI" use=" required" /> 
<xs ranyAttribute processContents="skip"/> 
</xs : complexType > 
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<xs : complexType name= " accessGroupType " > 

<xs : sequence> 

<xs: element name="accessBearer" type="xs : string" maxOccurs=" unbounded" /> 

</xs : sequence> 

<xs rattribute name="id" type="accessGroupIdType" use="required"/> 
</xs : complexType > 
<xs : complexType name="deliveryMethodType" > 

<xs : sequence> 

<xs:any namespace="##other" minOccurs="0" maxOccurs= "unbounded" processContents="lax"/> 

</xs : sequence> 

<xs rattribute name="accessGroupId" type="accessGroupIdType" use="optional"/> 

<xs rattribute name="associatedProcedureDescriptionURI" type="xs r anyURI" use="optional"/> 

<xs rattribute name="protectionDescriptionURI" type="xs r anyURI" use="optional"/> 

<xs rattribute name="sessionDescriptionURI" type="xs r anyURI" use=" required" /> 

<xs rattribute name="accessPointName" type="xs r anyURI" use="optional"/> 

<xs r anyAttribute processContents="skip"/> 
</xs r complexType > 
<xs r complexType name="nameType" > 

<xs r simpleContent> 

<xs r extension base= "xs r string" > 

<xs rattribute name="lang" type="xs r language" use= "optional "/> 
</xs r extension> 

</xs r simpleContent> 
</xs r complexType > 
<xs r simpleType name="accessGroupIdType" > 

<xs r restriction base="xs monNegativelnteger" > 

</xs r restriction> 
</xs r simpleType > 
<xs r complexType name= " requirement sType " > 

<xs r sequence> 

<xsr element name=" feature" type="xs runsignedint " minOccurs="l" maxOccurs= "unbounded" /> 

</xs r sequences> 
</xs r complexType > 

</xs:schema> 

1 1 .2.2 Example MBMS User Service Description Instances 

The following User Service Bundle Description instance is an example of a simple fragment. This fragment includes 
only the mandatory elements. 

<?xml version="l . 0" encoding="UTF-8" ?> 
<bundleDescription 

xmlns="urnr 3GPP rmetadata r 2005 rMBMS r userServiceDescription" 

xmlns rxsi = "http r //www. w3 . org/2001/XMLSchema-instance" > 

<userServiceDescription serviceld="urnr 3gpp r 0010120123hotdog" > 

<deliveryMethod sessionDescriptionURI="http r //www. example . com/3gpp/mbms/sessionl . sdp"/> 

</userServiceDescription> 
</bundleDescription> 

The following User Service Description instance is an example of a fuller fragment. 

<?xml version="l . 0" encoding="UTF-8" ?> 
<bundleDescription 

xmlns="urnr 3GPP rmetadata r 2005 rMBMS r userServiceDescription" 

xmlns rxsi="http r //www. w3 . org/2001/XMLSchema-instance" 

f ecDescriptionURI = "http r //www. example . com/3gpp/mbms/sessionl-f ec . sdp" > 

<userServiceDescription serviceld="urnr 3gpp r 1234567890coolcat " > 

<name lang="EN" >Welcome</name> 

<name lang= " DE " >Wi 1 lkommen< /name > 

<name lang="FR" >Bienvenue</name> 

<name lang="FI" >Tervetuloa</name> 

<serviceLanguage>EN</serviceLanguage> 

<serviceLanguage>DE</serviceLanguage> 

<requiredCapabilities> 
<feature>0</feature> 

</requiredCapabilities> 



ETSI 



3GPP TS 26.346 version 6.10.0 Release 6 81 ETSI TS 126 346 V6.10.0 (2007-10) 

<deliveryMethod accessGroupId="l" 

sessionDescriptionURI="http: //www. example . com/3gpp/mbms/sessionl . sdp"/> 
<deliveryMethod sessionDescriptionURI="http : //www. example . com/3gpp/mbms/session2 . sdp" 

associatedProcedureDescriptionURI="http: //www. example . com/3gpp/mbms/procedureX.xml"/> 
<deliveryMethod sessionDescriptionURI="http : //www. example . com/3gpp/mbms/session3 . sdp" 

associatedProcedureDescriptionURI="http: //www. example . com/3gpp/mbms/procedureY.xml"/> 
<deliveryMethod accessGroupId="2 " 

sessionDescriptionURI="http: //www. example . com/3gpp/mbms/session4 . sdp"/> 
<accessGroup id="l"> 

<accessBearer>3GPP . R6 . GERAN</accessBearer> 

<accessBearer>3GPP . R6 .UTRAN</accessBearer> 
</accessGroup> 
<accessGroup id="2"> 

<accessBearer>3GPP . R6 .UTRAN</accessBearer> 
</accessGroup> 
</userServiceDescription> 
</bundleDescription> 

1 1 .3 Service Protection Description Metadata Fragment 
1 1 .3.1 Definition of the Protection Description 

The security description is referenced by the protectionDescriptionURI of a deliveryMethod element. The security 
description fragment shall be identified by the MIME type "application/mbms protection-description+xml" as defined in 
Annex C.6. 

The root element of the security description is the securityDescription element. It contains three different elements, the 
key Id element identities the key(s) for each media flow, the keyManagemen element the keymanagement servers that 
the load is distributed over and the parameters in use, and the fecProtection element that configures the FEC protection 
of the point to multi-point distributed key flows. 

The keyManagement element defines the list of key management servers (i.e. BM-SC). The MBMS UE must register 
with a key management server to receive key material. A receiver shall select a key managment server following the 
same procedure defined for selecting a file repair server defined in sub-clause 9.3.5. 

The attribute uiccKeyManagement defines whether UICC based key management is required for the present MBMS 
User Service. 

The ojfsetTime and randomTime Period attributes define the back off behavior of the UE when requesting MSKs. This 
uses the procedure defined in sub-clause 9.3.4 where ojfsetTime specifies the offset time defined in sub-clause 9.3.4.1 
and randomTimePeriod the length of the random window in accordance with sub-clause 9.3.4.2. The units for both 
attributes are in seconds. 

The element keyld contains a list of media flows for which keys are required. For each media flow a key identifier is 
provide in addition to that media flows additional security parameters. The media flow is identified by a destination 
tuple providing an address followed by a port number separated by a "/", i.e. <IP-destination-address>/<destination- 
port>. The port number is for RTP session the RTP port number, and not RTCP's. Additional security parameters are 
srtpAuthenticationTagLength and srtpMKILength that are only applicable for RTP sessions that uses SRTP. The MSK 
element identifies the key uniquely by specifying both the keyDomainID and the MSKID as defined in sub-clause 
6.3.2.1 of 3GPP TS 33.246 [20]. The MSKID is 4 bytes long binary with byte 3 and 4 equal to 0x00, i.e. the current key 
that are base64 [82] when written into the element. The keyDomainID is a 3 byte long binary value as specified in sub- 
clause 6.3.2.1 of [20] and shall also be base64 encoded when written in the XML document. 

The attribute srtpAuthenticationTagLength defines the length of SRTP authentication tag in bytes. It has a default value 
of 10 bytes. For media flows using SRTP the attribute must be used to specify any value other than the default one. 

The attribute srtpMKILength defines the length of SRTP MKI field in bytes. The default value is 2 bytes. For media 
flows using SRTP the attribute must be used to specify any value other than the default one. 

The presence of the fecProtection element indicates that any MIKEY packet with an multicast destination IP address 
equal to any of the used destination address in the User Service Bundle Description instance" s delivery methods, are 
FEC protected and encapsulated in FEC source packets, see sub-clause 8.2.2.4. The attributes fecEncodingId, 
fecInstancelD, and fecOtiExtension specify the FEC payload ID used in the source packet. All service protection 
descriptions referenced by a User Service Bundle Description instance shall use the same FEC parameters. 

XML schema for Security Description: 
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<?xml version="l . 0" encoding="UTF-8" ?> 

<xs : schema xmlns="urn: 3GPP rmetadata : 2005 :MBMS : securityDescription" 
xmlns :xs="http : //www. w3 . org/2 OOl/XMLSchema" 

targetNamespace="urn: 3GPP rmetadata : 2 005 :MBMS : securityDescription" elementFormDefault= "qualified" > 
<xs : element name= " securityDescription" type= " securityDescriptionType" /> 
<xs : complexType name= " securityDescriptionType " > 
<xs : sequence> 

<xs: element name="keyManagement " type="keyManagementType" minOccurs=" 0"/> 
<xs: element name="keyld" type="keyIdType" maxOccurs= "unbounded" /> 
<xs: element name="f ecProtection" type="f ecProtectionType" minOccurs=" 0"/> 
<xs:any namespace="##other" minOccurs=" 0" maxOccurs= "unbounded" processContents="lax"/> 
</xs : sequence> 

<xs ranyAttribute processContents="skip"/> 
</xs : complexType > 

<xs : complexType name= " keyManagementType " > 
<xs : sequence> 

<xs: element name="serverURI" type="xs : anyURI" maxOccurs= "unbounded" /> 

<xs:any namespace="##other" minOccurs=" 0" maxOccurs= "unbounded" processContents="lax"/> 
</xs : sequence> 

<xs : attribute name="of f setTime" type="xs runsignedLong" use=" optional" def ault="0"/> 
<xs : attribute name="randomTimePeriod" type="xs runsignedLong" use= "optional" def ault="0"/> 
<xs : attribute name="uiccKeyManagement " type="xs : boolean" use="optional" def ault="true"/> 
<xs ranyAttribute processContents="skip"/> 
</xs : complexType > 

<xs : complexType name= " keyldType " > 
<xs : sequence> 

<xs: element name="mediaFlow" maxOccurs= "unbounded" > 
<xs : complexType > 
<xs : sequence> 

<xs: element name="MSK" type="MSKType" maxOccurs="l"/> 
</xs : sequence> 

<xs rattribute name="f lowID" type="xs : string" use="required"/> 
<xs : attribute name= " srtpAuthenticationTagLength" type= "xs : nonNegativelnteger " 

use= "optional" def ault="10"/> 
<xs rattribute name="srtpMKILength" type="xs : nonNegativelnteger" use=" optional" 

default="2"/> 
<xs ranyAttribute processContents="skip"/> 
</xs : complexType > 
</xs :element> 
</xs : sequence> 
</xs : complexType > 
<xs : complexType name="f ecProtectionType" > 

<xs rattribute name="f ecEncodingId" type="xs runsignedLong" use= "optional" def ault=" 0"/> 
<xs rattribute name="f eclnstanceld" type="xs runsignedLong" use="optional"/> 
<xs rattribute name="f ecOtiExtension" type="xs r string" use="optional"/> 
<xs ranyAttribute processContents="skip"/> 
</xs r complexType > 
<xs r complexType name="MSKType" > 
<xs r sequence> 

<xsr element name="keyDomainID" type="xs rbase64Binary" minOccurs="l" maxOccurs="l"/> 
<xsr element name="MSKID" type="MSKIDType" minOccurs="l" maxOccurs="l"/> 
</xs r sequence> 
</xs r complexType > 
<xs r simpleType name="MSKIDType" > 

<xs r restriction base="xs rbase64Binary" > 

<xs r length value="4"/> 
</xs r restriction> 
</xs r simpleType > 
</xs r schema> 

1 1 .3.2 Example of a Security Description: 

<?xml version="l . 0" encoding="UTF-8" ?> 
< securityDescription 

xmlns="urnr 3GPP rmetadata r 2005 rMBMS r securityDescription" 
xmlns rxsi = "http r //www. w3 . org/2001/XMLSchema-instance" > 
< keyManagement 

of f setTime="5" 
randomTimePeriod= "10" 
uiccKeyManagement="true"> 

<serverURI>httpr //register . operator .umts/</serverURI> 
<serverURI>httpr //register2 . operator .umts/</serverURI> 
< /keyManagement > 
<keyld> 

<mediaFlow flowID="224 . 1 . 2 . 3/4002 " > 
<MSK> 

<keyDomainID>aMoM</keyDomainID> 
<MSKID>aMoAAA==</MSKID> 



ETSI 



3GPP TS 26.346 version 6.10.0 Release 6 83 ETSI TS 126 346 V6.10.0 (2007-10) 

</iyiSK> 

</mediaFlow> 

<mediaFlow f lowID="224 .1.2. 3/4004" srtpAuthenticationTagLength="4" > 
<MSK> 

<keyDomainID>GM8M</keyDomainID> 
<MSKID>aMkAAA==</MSKID> 
</MSK> 
</mediaFlow> 
</keyId> 
< fee Protect ion 

f ecEncodingId= " 1 " 
f eclnstanceld= " " 

fecOtiExtension="lSCxWEMNe3 97m24SwgyRhg=="/> 
</securityDescription> 

1 1 .4 Service Protection Registration Format 

11.4.1 Data Format 

The below XML schema defines a format used to register to the keymanagement servers according to the procedure in 
TS 33.246. The MIME type for this format is defined in appendix C.9. The servicelD element identifies the service 
uniquely and is the same servicelD used in the userServiceDescription format defined in sub-clause 1 1.2.1. 

<?xml version="l . 0" encoding="UTF-8" ?> 

<xs : schema xmlns :xs="http : //www. w3 . org/2 OOl/XMLSchema" 

targetNamespace="urn: 3GPP rmetadata : 2005 :MBMS : securityRegistration" 
elementFormDefault= "qualified" attributeFormDefault= "unqualified" > 
<xs : element name="mbmsSecurityRegister" > 
<xs : annotation> 

<xs : document at ion>MBMS Security Registration according to TS 33 . 246</xs :documentation> 
</xs : annotation> 
<xs : complexType> 
<xs : sequence> 

<xs: element name=" servicelD" type="xs : anyURI" maxOccurs= "unbounded" minOccurs="l"/> 
<xs:any namespace="##other" minOccurs=" 0" maxOccurs= "unbounded" 
processContents= " lax" /> 
</xs : sequence> 
<xs ranyAttribute processContents="skip"/> 
</xs : complexType> 
</xs : element> 
</xs : schema> 

11.4.2 Example 

The below example is used to register to a service identifed by the servicelD " 
urn:3gpp:mbms:example:serivce:identification:123456789abcdef". 

<?xml version="l . 0" encoding="UTF-8" ?> 

<mbmsSecurityRegister xmlns="urn: 3GPP rmetadata : 2005 :MBMS : securityRegistration" 

xmlns :xsi="http: //www.w3 . org/2 l/XMLSchema- instance " > 

<serviceID>urn: 3gpp :mbms : example : serivce : identification: 123456789abcdef </serviceID> 
</mbmsSecurityRegister> 

1 1 .5 Service Protection De-Registration Format 
11.5.1 Data Format 

This format is used to de-register from the keymanagement server(s) according to the procedure in TS 33.246. The 
MIME type for this format is defined in appendix CIO. The servicelD element is defined exactly as in sub-clause 
11.4.1. 

<?xml version="l . 0" encoding="UTF-8" ?> 

<xs : schema xmlns :xs="http : //www. w3 . org/2 00 l/XMLSchema" 

targetNamespace="urn: 3GPP rmetadata : 2005 :MBMS : securityDeregistration" 
elementFormDefault= "qualified" attributeFormDefault= "unqualified" > 
<xs : element name= "mbmsSecurityDeregister " > 
<xs : annotation> 

<xs : document at ion>MBMS Security Deregistration according to TS 33 . 246</xs :documentation> 
</xs : annotation> 
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<xs : complexType> 
<xs : sequence> 

<xs: element name="serviceID" type="xs : anyURI" maxOccurs= "unbounded" minOccurs="l"/> 
<xs:any namespace="##other" minOccurs=" 0" maxOccurs= "unbounded" 
processContents= " lax" / > 
</xs : sequence> 
<xs ranyAttribute processContents="skip"/> 
</xs : complexType> 
</xs : element> 
</xs : schema> 

11.5.2 Example 

The below example is used to de-register from the services identifed by the servicelD " 
urn:3gpp:mbms:example:serivce:identification:123456789abcdef". 

<?xml version="l . 0" encoding="UTF-8" ?> 

<mbmsSecurityDeregister xmlns="urn: 3GPP rmetadata : 2005 :MBMS : securityDeregistration" 

xmlns :xsi="http : //www. w3 . org/2001/XMLSchema-instance" > 

<serviceID>urn: 3gpp :mbms : example : serivce : identification: 123456789abcdef </serviceID> 
</mbmsSecurityDeregister> 

1 1 .6 Service Protection IVISK Request Format 

11.6.1 Data Format 

This format is used to request from the keymanagement server(s) the delivery of one or more MSK identities as defined 
in sub-clause 1 1.3.1. The MIME type for this format is defined in appendix C.8. 

<?xml version="l . 0" encoding="UTF-8" ?> 
<xs : schema 

xmlns :xs="http : //www. w3 . org/2 OOl/XMLSchema" 

xmlns="urn: 3GPP rmetadata : 2005 :MBMS rmskRequest" 

targetNamespace= "urn : 3GPP : metadata : 2 05 : MBMS : mskRequest " 

elementFormDefault= "qualified" 

attributeFormDefault= "unqualified" > 

<xs : element name= "mbmsMSKRequest " > 
<xs : annotation> 

<xs : documentation> 

MBMS MSK Request as defined by 3GPP TS 26.346 and 3GPP TS 33.246 
</xs : documentation> 
</xs : annotation> 
<xs : complexType> 
<xs : sequence> 

<xs:element name="MSK" type="MSKType" minOccurs="l" maxOccurs= "unbounded" /> 
</xs : sequence> 

<xs ranyAttribute processContents="skip"/> 
</xs : complexType> 
</xs : element> 

<xs : complexType name="MSKType" > 
<xs : sequence> 

<xs: element name="keyDomainID" type="xs :base64Binary" minOccurs="l" maxOccurs="l"/> 
<xs:element name="MSKID" type="MSKIDType" minOccurs="l" maxOccurs="l"/> 
</xs : sequence> 
</xs : complexType > 
<xs : simpleType name="MSKIDType" > 

<xs : restriction base="xs :base64Binary" > 

<xs : length value="4"/> 
</xs : restriction> 
</xs : simpleType > 
</xs : schema> 

11.6.2 Example 

The below example is used to request a single MSK with keyDomainID "uHCd" and a MSK ID part "aMkAAA==". 

<?xml version="l . 0" encoding="UTF-8" ?> 
<mbmsMSKRequest 

xmlns :xsi="http : //www. w3 . org/2001/XMLSchema-instance" 
xmlns="urn: 3GPP rmetadata : 2 005 :MBMS rmskRequest " > 
<MSK> 

<keyDomainID>uHCd< /keyDomainID > 

<MSKID>aMkAAA==</MSKID> 
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</MSK> 
< /mbmsMSKRequest > 

1 1 .7 Service Protection Registration and De-Registration 
Response Format 

11.7.1 Data Format 

This format is used in the response of the keymanagement server(s) to a Service Protection Registration or De- 
Registration message. Service Protection Registration message format is defined in clause 11.4 and the Service 
Protection De-Registration message format in clause 11.5. The format of the response codes are defined in 3GPP 
TS 33.246 [20]. The MIME Media type for this format is defined in appendix C.13. 

<?xml version="l . 0" encoding="UTF-8" ?> 

<xs : schema xmlns="urn: 3GPP : metadata : 2 05 :MBMS : securityRegistrationResponse" 
xmlns :xs="http : //www. w3 . org/2 OOl/XMLSchema" 

targetNamespace="urn: 3GPP : metadata : 2 05 :MBMS : securityRegistrationResponse" 
elementFormDefault= "qualified" attributeFormDefault= "unqualified" > 
<xs : element name="mbmsSecurityRegisterResponse" > 
<xs : annotation> 

<xs : document at ion>MBMS Security Registration Response according to TS 
33 . 246</xs :documentation> 
</xs : annotation> 
<xs : complexType> 
<xs : sequence> 

<xs: element name=" Response" type="ResponseType" maxOccurs= "unbounded" /> 
<xs:any namespace="##other" minOccurs="0"/> 
</xs : sequence> 
</xs : complexType> 
</xs :element> 

<xs : complexType name= " ResponseType " > 
<xs : sequence> 

<xs: element name="serviceID" type="xs : anyURI"/> 
<xs:element name="ResponseCode" type="xs : string"/> 
<xs:any namespace="##other" processContents="lax" minOccurs=" 0"/> 
</xs : sequence> 
</xs : complexType > 
</xs : schema> 



1 1 .7.2 Example 

<?xml version="l . 0" encoding="UTF-8" ?> 

<mbmsSecurityRegisterResponse xmlns="urn: 3GPP : metadata : 2 05 :MBMS : securityRegistrationResponse" 
xmlns :xsi="http : //www. w3 . org/2001/XMLSchema-instance" 

xsi : schemaLocation="urn: 3GPP rmetadata : 2005 :MBMS : securityRegistrationResponse" > 
<Response> 

<serviceID>urn: 3gpp :mbms : example : service : identification: 123456789abcdef </serviceID> 
<ResponseCode>2 OK</ResponseCode> 
</Response> 
<Response> 

<serviceID>urn: 3gpp :mbms : example : service : identification: f edcba987654321</serviceID> 
<ResponseCode>2 OK</ResponseCode> 
</Response> 
</mbmsSecurityRegisterResponse> 

1 1 .8 Service Protection IVISK Response Format 
11.8.1 Data Format 

This format is used in the response of the keymanagement server(s) to an MSK Request message. The MSK Request 
message format is defined in clause 11.6. The format of the response codes are defined in 3GPP TS 33.246 [20]. The 
MIME Media type for this format is defined in appendix C.12. 

<?xml version="l . 0" encoding="UTF-8" ?> 

<xs : schema xmlns="urn: 3GPP : metadata : 2 005 :MBMS rmskResponse" 

xmlns :xs="http: //www.w3 . org/200l/XMLSchema" 
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targetNamespace="urn: 3GPP rmetadata : 2005 :MBMS rmskResponse" elementFormDef ault = "qualif ied" 
attributeFormDefault= "unqualified" > 

<xs : element name="mbmsMSKResponse" > 
<xs : annotation> 

<xs : document at ion>MBMS Security MSK Request Response according to TS 
33 . 246</xs : documentation> 
</xs : annotation> 
<xs : complexType> 
<xs : sequence> 

<xs: element name=" Response" type="ResponseType" maxOccurs= "unbounded" /> 
<xs:any namespace="##other" minOccurs=" 0"/> 
</xs : sequence> 
</xs : complexType> 
</xs :element> 

<xs : complexType name="MSKType" > 
<xs : sequence> 

<xs: element name="keyDomainID" type="xs :base64Binary"/> 
<xs: element name="MSKID" type="MSKIDType"/> 
</xs : sequence> 
</xs : complexType > 
<xs : simpleType name="MSKIDType" > 

<xs : restriction base= "xs : base64Binary " > 

<xs : length value="4"/> 
</xs : restriction> 
</xs : simpleType > 

<xs : complexType name= " ResponseType " > 
<xs : sequence> 

<xs: element name="MSK" type="MSKType"/> 
<xs: element name="ResponseCode" type="xs : string" /> 
<xs:any namespace="##other" processContents="lax" minOccurs="0"/> 
</xs : sequence> 
</xs : complexType > 
</xs : schema> 



11.8.2 Example 



<?xml version="l . 0" encoding="UTF-8" ?> 

<mbmsMSKResponse xmlns="urn: 3GPP rmetadata : 2 05 :MBMS rmskResponse" 
xmlns :xsi="http : //www. w3 . org/2001/XMLSchema-instance" 
xsi : schemaLocation="urn: 3GPP rmetadata : 2 05 :MBMS rmskResponse" > 
<Response> 
<MSK> 

<keyDomainID>uHCd</keyDomainID> 
<]y[SKID>aMkAAA= = </MSKID> 
</MSK> 

<ResponseCode>2 OK</ResponseCode> 
</Response> 
<Response> 
<MSK> 

<keyDomainID>uHCd</keyDomainID> 
<MSKID>JMtEAA==</MSKID> 
</MSK> 

<ResponseCode>2 OK</ResponseCode> 
</Response> 
</mbmsMSKResponse> 



1 1 .9 MBMS Feature Requirements 

MBMS features enable the BM-SC to signal to the UE the set of capabilities that are required for the consumption of 
the MBMS user service. The required capability list is indicated in the MBMS User Service Description of the 
corresponding MBMS user service as defined in section 11.2.1. 

The MBMS UE shall not attempt to receive the service if it detects that at least one required capability, indicated in the 
USD, is not supported or not understood. The introduction of new features is possible and assumes that unidentified 
features shall be interpreted by the UE as a requirement that cannot be fulfilled. 



The following list of features is currently identified: 
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Table 2: MBMS Feature Requirement List 



Service Capability 


References 


Recognized Feature Values (Integer) 


Speech 


as defined in clause 10.2 





AMR-WB 


As defined in clause 10.2 


1 


Enhanced aacPlus 


as defined in clause 10.3 


2 


Extended AMR-WB 


as defined in clause 10.3 


3 


Synthetic audio 


as defined in clause 10.4 


4 


H.263 


as mentioned in clause 10.5 


5 


H.264 Level lb 


as defined in clause 10.5 
(Release 6) 


6 


Still images 


as defined in clause 10.6 


7 


Bitmap graphics 


as defined in clause 10.7 


8 


Vector graphics 


as defined in clause 10.8 


9 


Text 


as defined in clause 10.9 


10 


Timed text 


as defined in clause 10.10 


11 


3GPP file format 


as defined in clause 10.1 1 


12 



The list of feature may be extended in the future. 
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Annex A (normative): 
FLUTE Support Requirements 



This clause provides a table representation of the requirement levels for different features in FLUTE. Table A. 1 
includes requirements for an MB MS client and an MB MS server for FLUTE support as well as the requirements for a 
FLUTE client and a FLUTE server according to the FLUTE protocol (RFC 3926 [9]). The terms used in table A.l are 
described underneath. 

Table A.1 : Overview of the FLUTE support requirements in MBMS servers and clients 





FLUTE Client 

support requirement 

as per [9] 


MBMS FLUTE Client 

support requirement 

as per present 

document 


FLUTE Server use 

requirement as per 

[9] 


MBMS FLUTE Server 

use requirement as 

per present 

document 


FLUTE Blocking 
Algorithm 


Required 


Required 


Strongly 
recommended 


Required 


Symbol Encoding 
Algorithm 


Compact No-Code 
algorithm required. 

Other FEC building 

blocks are undefined 

optional plug-ins. 


Compact No-Code 
algorithm required. 

MBMS Forward Error 
Correction required 


Compact No-Code 

algorithm is the default 

option. 

Other FEC building 

blocks are undefined 

optional plug-ins. 


Compact No-Code 

algorithm is the default 

option. 

MBMS Forward Error 
Correction. 


Congestion Control 
Building Block (CCBB) 
/ Algorithm 


Congestion Control 

building blocks 

undefined. 


Single channel 
support required 


Single channel without 

additional CCBB given 

for the controlled 

network scenario. 


Single channel 
support required 


Content Encoding for 
FDT Instances 


Optional 


Optional 


Optional 


Shall not be used 


Content Encoding for 
any other file than 
FDT Instances 


Optional 


Required 


Optional 


Optional 


A flag active (header) 


Required 


Required 


Optional 


Not recommended to 
use 


B flag active (header) 


Required 


Required 


Optional 


Not recommended to 
use 


T flag active and SCT 
field (header) 


Optional 


Optional 


Optional 


Set to zero 


R flag active and ERT 
field (header) 


Optional 


Optional 


Optional 


Set to zero 


Content-Location 
attribute (FDT) 


Required 


Required 


Required 


Required 


TOI (FDT) 


Required 


Required 


Required 


Required 


FDT Expires attribute 
(FDT) 


Required 


Required 


Required 


Required 


Complete attribute 
(FDT) 


Required 


Required 


Optional 


Optional 


FEC-OTI-Maximum- 
Source-Block-Length 


Required 


Required 


Required 


Required 


FEC-OTI-Encoding- 
Symbol-Length 


Required 


Required 


Required 


Required 


FEC-OTI-Max- 

Number-of-Encoding- 

Symbols. 


Required 


Required 


Required 


Required 


FEC-OTI-FEC- 
Instance-ID 


Required 


Optional 


Required 


Optional 


FEC-OTI-Scheme- 
Specific-lnfo 


n/a 


Required 


n/a 


Required if MBMS 
FEC used 



The following are descriptions of the above terms: 
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Blocking algorithm: The blocking algorithms is used for the fragmentation of files. It calculates the source 
blocks from the source files. 

Symbol Encoding algorithm: The symbol encoding algorithm is used for the fragmentation of files. It 
calculates encoding symbols from source blocks for Compact No-Code FEC. It may also be used for other FEC 
schemes. 

Congestion Control Building Block: A building block used to limit congestion by using congestion feedback, 
rate regulation and receiver controls (RFC 3048 [17]). 

Content Encoding for FDT Instances: FDT Instance may be content encoded for more efficient transport, 
e.g. using ZLIB. 

Content Encoding for any other file than FDT Instances: Files may be content encoded for more efficient 
transport, e.g. using GZIP. 

A flag: The Close Session flag for indicating the end of a session to the receiver in the ALC/LCT header. 

B flag: The Close Object flag is for indicating the end of an object to the receiver in the ALC/LCT header. 

T flag: The T flag is used to indicate the use of the optional "Sender Current Time (SCT)" field (when T=l) in 
the ALC/LCT header. 

R flag: The R flag is used to indicate the use of the optional "Expected Residual Time (ERT) field in the 
ALC/LCT header. 

Content Location attribute: This attribute provides a URI for the location where a certain piece of content (or 
file) being transmitted in a FLUTE session is located. 

Transport Object Identifier (TOI): The TOI uniquely identifies the object within the session from which the 
data in the packet was generated. 

FDT Expires attribute: Indicates to the receiver the time until which the information in the FDT is valid. 

Complete attribute: This may be used to signal that the given FDT Instance is the last FDT Instance to be 
expected on this file delivery session. 

FEC-OTI-Maximum-Source-Block-Length: This parameter indicates the maximum number of source 
symbols per source block. 

FEC-OTI-Encoding-Symbol-Length: This parameter indicates the length of the Encoding Symbol in bytes. 

FEC-OTI-Max-Number-of-Encoding-Symbols: This parameter indicates the maximum number of Encoding 
Symbols that can be generated for a source block. 

FEC-OTI-FEC-Instance-ID: This field is used to indicate the FEC Instance ID, if a FEC scheme is used. 

FEC-OTI-Scheme-Specific-Info: Carries Object Transmission Information which is specific to the FEC scheme 
in use. 
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Annex B (normative): 
FEC encoder specification 



This Annex specifies the systematic Raptor forward error correction code and its apphcation to MBMS [7]. Raptor is a 
fountain code, i.e., as many encoding symbols as needed can be generated by the encoder on-the-fly from the source 
symbols of a block. The decoder is able to recover the source block from any set of encoding symbols only slightly 
more in number than the number of source symbols. 

The code described in this document is a Systematic code, that is, the original source symbols are sent unmodified from 
sender to receiver, as well as a number of repair symbols. 



B.1 Definitions, Symbols and Abbreviations 
B.1.1 Definitions 

For the purposes of this Annex and Annex E, the following terms and definitions apply. 

Source block: a block of ^ source symbols which are considered together for Raptor encoding purposes. 

Source symbol: the smallest unit of data used during the encoding process. All source symbols within a source block 
have the same size. 

Encoding symbol: a symbol that is included in a data packet. The encoding symbols consist of the source symbols and 
the repair symbols. Repair symbols generated from a source block have the same size as the source symbols of that 
source block. 

Systematic code: a code in which the source symbols are included as part of the encoding symbols sent for a source 
block. 

Repair symbol: the encoding symbols sent for a source block that are not the source symbols. The repair symbols are 
generated based on the source symbols. 

Intermediate symbols: symbols generated from the source symbols using an inverse encoding process . The repair 
symbols are then generated directly from the intermediate symbols. The encoding symbols do not include the 
intermediate symbols, i.e., intermediate symbols are not included in data packets. 

Symbol: a unit of data. The size, in bytes, of a symbol is known as the symbol size. 

Encoding symbol group: a group of encoding symbols that are sent together, i.e., within the same packet whose 
relationship to the source symbols can be derived from a single Encoding Symbol ID. 

Encoding Symbol ID: information that defines the relationship between the symbols of an encoding symbol group and 
the source symbols. 

Encoding packet: data packets that contain encoding symbols 

Sub-block: a source block is sometime broken into sub-blocks, each of which is sufficiently small to be decoded in 
working memory. For a source block consisting of ^ source symbols, each sub-block consists of ^ sub-symbols, each 
symbol of the source block being composed of one sub-symbol from each sub-block. 

Sub-symbol: part of a symbol. Each source symbol is composed of as many sub-symbols as there are sub-blocks in the 
source block. 

Source packet: data packets that contain source symbols. 

Repair packet: data packets that contain repair symbols. 
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B.1.2 Symbols 

/, j, X, h, a, b, d, V, m represent positive integers 

ceil(x) denotes the smallest positive integer which is greater than or equal to x 

choose(/j) denotes the number of ways j objects can be chosen from among / objects without repetition 

floor(x) denotes the largest positive integer which is less than or equal to x 

i % j denotes / modulo j 

X^Y denotes, for equal-length bit strings X and Y, the bitwise exclusive-or of X and Y 

A denote a symbol alignment parameter. Symbol and sub-symbol sizes are restricted to be multiples of A. 

A^ denotes the transposed matrix of matrix A 

A"^ denotes the inverse matrix of matrix A 

K denotes the number of symbols in a single source block 

Kmax denotes the maximum number of source symbols that can be in a single source block. Set to 8192. 

L denotes the number of pre-coding symbols for a single source block 

S denotes the number of LDPC symbols for a single source block 

H denotes the number of Half symbols for a single source block 

C denotes an array of intermediate symbols, C[0], C[l], C[2],..., C[L-1] 

C" denotes an array of source symbols, C"[0], C"[l], C"[2],. . ., C'[K-\] 

X a non-negative integer value 

Vo, Vi two arrays of 4-byte integers, VoM, VoLl],..., Vo[255] and yi[0], ViLl],..., yi[255] 

Rand[X, /, m] a pseudo-random number generator 

Deg[v] a degree generator 

LTEnc[^, C Xd, a, b)] a LT encoding symbol generator 

Trip[^, X] a triple generator function 

G the number of symbols within an encoding symbol group 

N the number of sub-blocks within a source block 

T the symbol size in bytes. If the source block is partitioned into sub-blocks, then T = T"-N. 

T" the sub-symbol size, in bytes. If the source block is not partitioned into sub-blocks then T" is not 

relevant. 

F the file size, for file download, in bytes 

/ the sub-block size in bytes 

P for file download, the payload size of each packet, in bytes, that is used in the recommended derivation of 

the file download transport parameters. For streaming, the payload size of each repair packet, in bytes, 
that is used in the recommended derivation of the streaming transport parameters. 

Q Q = 65521, i.e., Q is the largest prime smaller than 2^^ 

Z the number of source blocks, for file download 

J(K) the systematic index associated with K 
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G 
I. 

^SxH 



denotes any generator matrix 
denotes the SxS identity matrix 
denotes the SxH zero matrix 



B.1.3 Abbreviations 

For the purposes of the present document, the following abbreviations apply: 



ESI 

LDPC 

LT 

SBN 

SBL 



Encoding Symbol ID 

Low Density Parity Check 

Luby Transform 

Source Block Number 

Source Block Length (in units of symbols) 



B.2 Overview 



The Raptor forward error correction code can be applied to both the MB MS file delivery and MB MS streaming 
applications described in the main body of this document. Raptor code aspects which are specific to each of these 
applications are discussed in sub-clauses B.3 and B.4 of this document. 

The principle component of the systematic Raptor code is the basic encoder described in sub-clause B.5. First, it is 
described how to derive values for a set of intermediate symbols from the original source symbols such that knowledge 
of the intermediate symbols is sufficient to reconstruct the source symbols. Secondly, the encoder produces repair 
symbols which are each the exclusive OR of a number of the intermediate symbols. The encoding symbols are the 
combination of the source and repair symbols. The repair symbols are produced in such a way that the intermediate 
symbols and therefore also the source symbols can be recovered from any sufficiently large set of encoding symbols. 

This document defines the systematic Raptor code encoder. A number of possible decoding algorithms are possible. An 
efficient decoding algorithm is provided in Annex E. 

The construction of the intermediate and repair symbols is based in part on a pseudo-random number generator 
described in sub-clause B.5. This generator is based on a fixed set of 512 random numbers which must be available to 
both sender and receiver. These are provided in sub-clause B.7. 

Finally, the construction of the intermediate symbols from the source symbols is governed by a "systematic index", 
values of which are provided in sub-clause B.6 for source block sizes from 4 source symbols to Kmax =8192 source 
symbols. 



B.3 File download 



B.3.1 Source block construction 
B.3.1.1 General 

In order to apply the Raptor encoder to a source file, the file may be broken into Z > 1 blocks, known as source blocks. 
The Raptor encoder is applied independently to each source block. Each source block is identified by a unique integer 
Source Block Number (SBN), where the first source block has SBN zero, the second has SBN one, etc. Each source 
block is divided into a number, K, of source symbols of size T bytes each. Each source symbol is identified by a unique 
integer Encoding Symbol Identifier (ESI), where the first source symbol of a source block has ESI zero, the second has 
ESI one, etc. 

Each source block with K source symbols is divided into A^ > 1 sub-blocks, which are small enough to be decoded in the 
working memory. Each sub-block is divided into K sub-symbols of size T". 
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Note that the value of K is not necessarily the same for each source block of a file and the value of T" may not 
necessarily be the same for each sub-block of a source block. However, the symbol size T is the same for all source 
blocks of a file and the number of symbols, K is the same for every sub-block of a source block. Exact partitioning of 
the file into source blocks and sub-blocks is described in sub-clause B.3.1.2 below. 

Figure B.3.1.1.-1 shows an example source block placed into a two dimensional array, where each entry is a r"-byte 
sub-symbol, each row is a sub-block and each column is a source symbol. In this example, the value of T" is the same 
for every sub-block. The number shown in each sub- symbol entry indicates their original order within the source block. 
For example, the sub-symbol numbered ^ contains bytes T"-^ through r"-(^+l)-l of the source block. Then, source 
symbol / is the concatenation of the /th sub-symbol from each of the sub-blocks, which corresponds to the sub-symbols 
of the source block numbered /, K+i, 2-K-\-i,..., (N-l)-K-\-i. 
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Figure B.3.1.1-1 - Source symbols from sub-symbols- the 3 highlighted columns show source 

symbols 0, 2 and K-^ 



B.3.1 .2 Source block and sub-block partitioning 

The construction of source blocks and sub-blocks is determined based on five input parameters, F, A, T, Z and A^ and a 
function Partition[]. The five input parameters are defined as follows: 

F the size of the file, in bytes 

- A a symbol alignment parameter, in bytes 

T the symbol size, in bytes, which must be a multiple of A 

- Z the number of source blocks 

- N the number of sub-blocks in each source block 

These parameters shall be set so that ceil(ceil(F/7)/Z) < Kmax- Recommendations for derivation of these parameters are 
provided in sub-clause B.3.4. 

The function Partition[] takes a pair of integers (/, J) as input and derives four integers (II, Is, Ju Js) as output. 
Specifically, the value of Partition [/, 7] is a sequence of four integers (7^, h, Ju Js)r where II = ceil(///). Is = floor(//7), 
Jl=I-Is- J and Js=J- Jl- Partition [] derives parameters for partitioning a block of size / into / approximately equal 
sized blocks. Specifically, /^ blocks of length /^ and Js blocks of length 7^. 

The source file shall be partitioned into source blocks and sub-blocks as follows: 

Let, 

Kt = CQil(F/T) 

(Kl, Ks, Zl, Zs) = Partition[/r„ Z ] 

(Tl, Ts, Nl, Ns) = Partition[77A, A^ ] 

Then, the file shall be partitioned into Z = Zl-\-Zs contiguous source blocks, the first Zl source blocks each having 
length Kl'T bytes and the remaining Zs source blocks each having TT^T bytes. 
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If KtT> F then for encoding purposes, the last symbol shall be padded at the end with Kj-T- F zero bytes. 

Next, each source block shall be divided into N = Nl-\- Ns contiguous sub-blocks, the first A^^ sub-blocks each 
consisting of K contiguous sub-symbols of size of Tl A and the remaining Ns sub-blocks each consisting of K 
contiguous sub-symbols of size of Ts A. The symbol alignment parameter A ensures that sub-symbols are always a 
multiple of A bytes. 

Finally, the mth symbol of a source block consists of the concatenation of the mth sub- symbol from each of the A^ sub- 
blocks. 



B.3.2 Encoding packet construction 



B.3.2.1 General 

Each encoding packet contains the following information: 

- Source Block Number (SBN) 

- Encoding Symbol ID (ESI) 

- encoding symbol(s) 

Each source block is encoded independently of the others. Source blocks are numbered consecutively from zero. 

Encoding Symbol ID values from to ^-1 identify the source symbols. Encoding Symbol IDs from K onwards identify 
repair symbols. 

B.3.2. 2 Encoding packet construction 

Each encoding packet either consists entirely of source symbols (source packet) or entirely of repair symbols (repair 
packet). A packet may contain any number of symbols from the same source block. In the case that the last symbol in 
the packet includes padding bytes added for EEC encoding purposes then these bytes need not be included in the packet. 
Otherwise, only whole symbols shall be included. 

The Encoding Symbol ID, X, carried in each source packet is the Encoding Symbol ID of the first source symbol carried 
in that packet. The subsequent source symbols in the packet have Encoding Symbol IDs, X+1 to X+G-1, in sequential 
order, where G is the number of symbols in the packet. 

Similarly, the Encoding Symbol ID, X, placed into a repair packet is the Encoding Symbol ID of the first repair symbol 
in the repair packet and the subsequent repair symbols in the packet have Encoding Symbol IDs X+1 to X+G-1 in 
sequential order, where G is the number of symbols in the packet. 

Note that it is not necessary for the receiver to know the total number of repair packets. The G repair symbol triples 
(J[0], a[0],b[0]),..., (J[G-1], a[G-l], b[G-l]) for the repair symbols placed into a repair packet with ESI X are 
computed using the Triple generator defined in B. 5. 3. 4 as follows: 

For each / = 0, ..., G-1 

(d[il a[il b[i]) = Trip[^,X+/] 

The G repair symbols to be placed in repair packet with ESI X are calculated based on the repair symbol triples as 
described in sub-clause B.5.3 using the intermediate symbols C and the LT encoder LTenc[^, C, (d[i], a[i], b[i])]. 



B.3.3 Transport 



This sub-clause describes the information exchange between the Raptor encoder/decoder and any transport protocol 
making use of Raptor forward error correction for file delivery. 

The Raptor encoder and decoder for file delivery require the following information from the transport protocol: 

The file size, F, in bytes 
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The symbol alignment parameter, A 

The symbol size, T, in bytes, which must be a multiple of A 

The number of source blocks, Z 

The number of sub-blocks in each source block, A^ 
The Raptor encoder for file delivery additionally requires: 

the file to be encoded, F bytes 
The Raptor encoder supplies the transport protocol with encoding packet information consisting, for each packet, of: 
Source Block Number (SBN) 

Encoding Symbol ID (ESI) 

encoding symbol(s) 
The transport protocol shall communicate this information transparently to the Raptor decoder. 
Suitable transport protocols based on FLUTE/ALC and HTTP are defined in this specification. 

B.3.4 Example parameters 
B.3.4.1 Parameter derivation algorithm 

This sub-clause provides recommendations for the derivation of the four transport parameters. A, T, Z and N. This 
recommendation is based on the following input parameters: 

F the file size, in bytes 

W a target on the sub-block size, in bytes 

- P the maximum packet payload size, in bytes, which is assumed to be a multiple of A 

- A the symbol alignment factor, in bytes 

- Kmax the maximum number of source symbols per source block. 

- Kmin a minimum target on the number of symbols per source block 

- Gmax a maximum target number of symbols per packet 

Based on the above inputs, the transport parameters T, Z and N are calculated as follows: 
Let, 

G = min{ceil(P -Kmin^F), PI A, Gmax) - the approximate number of symbols per packet 

T = floor(P/(A-G))-A 

Kt = ceil(F/7) - the total number of symbols in the file 

Z = ceil(Kt IKmax) 

A^= min{ceil(ceil( KJZ)-TIW), TIA} 

The values of G and A^ derived above should be considered as lower bounds. It may be advantageous to increase these 
values, for example to the nearest power of two. In particular, the above algorithm does not guarantee that the symbol 
size, r, divides the maximum packet size, P, and so it may not be possible to use the packets of size exactly P. If, 
instead, G is chosen to be a value which divides PI A, then the symbol size, T, will be a divisor ofP and packets of size 
P can be used. 

Recommended settings for the input parameters, W, A, Kmin and Gmax are as follows: 
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W=256KB 



A = 4 



KMm= 1024 



Gmax - 10 



B.3.4.2 Examples 



The above algorithm leads to transport parameters as shown in Table B. 3.4.2-1 below, assuming the recommended 
values for W, A, Kmin and Gmax and P - 512: 

Table B.3.4.2-1 



File size F G ^l^^f G*T K, 



Source 
blocks 



Sub- 
blocks A'^ 



K, 



K, 



TrA TsA 



100 KB 6 84 504 1,220 



100 KB 

300 KB 

1,000 KB 

3,000 KB 

10,000 KB 



8 
2 
1 
1 
1 



64 
256 
512 
512 
512 



512 1,600 

512 1,200 

512 2,000 

512 6,000 

512 20,000 



1 ,220 ^ 220 ^'^ ^^^ 



1 


1,600 


1,600 


N/A 


N/A 


2 


1,200 


1,200 


128 


128 


5 


2,000 


2,000 


104 


100 


12 


6,000 


6,000 


44 


40 


14 


6,666 


6,667 


40 


36 



B.4 Streaming 

B.4.1 Source block construction 

A source block is constructed by the transport protocol, for example as defined in this document, making use of the 
Systematic Raptor Forward Error Correction code. The symbol size, T, to be used for source block construction and the 
repair symbol construction are provided by the transport protocol. The parameter T shall be set so that the number of 
source symbols in any source block is at most Kmax- 

Recommended parameters are presented in sub-clause BAA. 

B.4. 2 Encoding packet construction 

As described in sub-clause B.4. 3., each repair packet contains the following information: 

- Source Block Number (SBN) 

- Encoding Symbol ID (ESI) 

- Source Block Length (SBL) 

- repair symbol(s) 

The number of repair symbols contained within a repair packet is computed from the packet length. The ESI values 
placed into the repair packets and the repair symbol triples used to generate the repair symbols are computed as 
described in sub-clause B.3.2.2. 
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B.4.3 Transport 



This sub-clause describes the information exchange between the Raptor encoder/decoder and any transport protocol 
making use of Raptor forward error correction for streaming. 

The Raptor encoder for streaming requires the following information from the transport protocol for each source block: 

- The symbol size, T, in bytes 

The number of symbols in the source block, K 

- The Source Block Number (SBN) 

- The source symbols to be encoded, ^T bytes 

The Raptor encoder supplies the transport protocol with encoding packet information consisting, for each repair packet, 
of: 

- Source Block Number (SBN) 

- Encoding Symbol ID (ESI) 

- Source Block Length (SBL) 

- repair symbol(s) 

The transport protocol shall communicate this information transparently to the Raptor decoder. 
A suitable transport protocol is defined in this specification. 

B.4.4 Example parameters 
B.4.4.1 Parameter derivation algorithm 

This sub-clause provides recommendations for the derivation of the transport parameter T. This recommendation is 
based on the following input parameters: 

- B the maximum source block size, in bytes 

- P the maximum repair packet payload size, in bytes, which is a multiple of A 

- A the symbol alignment factor, in bytes 

- f^MAx the maximum number of source symbols per source block. 

- Kmin a minimum target on the number of symbols per source block 

- Gmax a maximum target number of symbols per repair packet 

A requirement on these inputs is that CQi\{BIP) < Kmax- Based on the above inputs, the transport parameter Tis 
calculated as follows: 

Let, 

G = min{ceil(P -Kmin^B), P/A, Gmax} - the approximate number of symbols per packet 

T = nooY(P/(A'G)yA 

The value of T derived above should be considered as a guide to the actual value of T used. It may be advantageous to 
ensure that T divides into P, or it may be advantageous to set the value of T smaller to minimize wastage when full size 
repair symbols are used to recover partial source symbols at the end of lost source packets (as long as the maximum 
number of source symbols in a source block does not exceed Kmax)- Furthermore, the choice of T may depend on the 
source packet size distribution, e.g., if all source packets are the same size then it is advantageous to choose T so that 
the actual payload size of a repair packet P", where P" is a. multiple of T, is equal to (or as few bytes as possible larger 
than) the number of bytes each source packet occupies in the source block. 
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Recommended settings for the input parameters, A, Kmin and Gmax are as follows: 

B.4.4.2 Examples 

The above algorithm leads to transport parameters as shown in Table B. 4.4.2-1 below, assuming the recommended 
values for A, Kmin and Gmax and P = 512: 

Table B.4.4.2-1 



Max source block size B 


G 


Symbol size T 


GT 


40 KB 


10 


48 


480 


160 KB 


4 


128 


512 


640 KB 


1 


512 


512 



B.5 Systematic Raptor encoder 
B.5.1 Encoding overview 

The systematic Raptor encoder is used to generate repair symbols from a source block that consists of K source 
symbols. 

Symbols are the fundamental data units of the encoding and decoding process. For each source block (sub-block) all 
symbols (sub-symbols) are the same size. The atomic operation performed on symbols (sub-symbols) for both 
encoding and decoding is the exclusive-or operation. 

Let C"[0],. . ., C"[K-\] denote the K source symbols. 

Let C[0],. . ., C[L-1] denote L intermediate symbols. 

The first step of encoding is to generate a number, L> K, of intermediate symbols from the K source symbols. In this 
step, ^source triples (J[0], a[0], b[0]), ..., (d[K-l], a[K-l], b[K-l]) are generated using the Trip[] generator as 
described in sub-clause B.5. 4.4. The K source triples are associated with the K source symbols and are then used to 
determine the L intermediate symbols C[0],. . ., C[L-1] from the source symbols using an inverse encoding process. This 
process can be can be realized by a Raptor decoding process. 

Certain 'pre-coding relationships' must hold within the L intermediate symbols. Sub-clause B.5. 2 describes these 
relationships and how the intermediate symbols are generated from the source symbols. 

Once the intermediate symbols have been generated, repair symbols are produced and one or more repair symbols are 
placed as a group into a single data packet. Each repair symbol group is associated with an Encoding Symbol ID (ESI) 
and a number, G, of encoding symbols. The ESI is used to generate a triple of three integers, (J, a, b) for each repair 
symbol, again using the Trip[] generator as described in sub-clause B.5. 4.4. This is done as described in sub-clauses B.3 
and B.4 using the generators described in sub-clause B.5. 4 . Then, each (d,a,b)-tviple is used to generate the 
corresponding repair symbol from the intermediate symbols using the LTEnc[^, C[0],..., C[L-1], (d,a,b)] generator 
described in sub-clause B.5. 4. 3. 
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B.5.2 First encoding step: Intermediate symbol Generation 
B.5.2.1 General 

The first encoding step is a pre-coding step to generate the L intermediate symbols C[0], . . ., C[L-1] from the source 
symbols C"[0], . . ., C"[^-l]. The intermediate symbols are uniquely defined by two sets of constraints: 

1 . The intermediate symbols are related to the source symbols by a set of source symbol triples. The generation of 
the source symbol triples is defined in sub-clause B.5.2. 2 using the the Trip[] generator as described in sub- 
clause B.5.4.4. 

2. A set of pre-coding relationships hold within the intermediate symbols themselves. These are defined in sub- 
clause B.5.2. 3. 

The generation of the L intermediate symbols is then defined in sub-clause 5.2.4. 

B.5.2. 2 Source symbol triples 

Each of the K source symbols is associated with a triple (J[/], a[i\, h[iY) for 0<i<K. The source symbol triples are 
determined using the Triple generator defined in sub-clause B.5.4.4 as: 

For each i,0<i<K 

(d[il a[i], b[i]) =Trip[/r, /] 

B.5.2. 3 Pre-coding relationships 

The pre-coding relationships amongst the L intermediate symbols are defined by expressing the last L-K intermediate 
symbols in terms of the first ^intermediate symbols. 

The last L-K intermediate symbols C[K],...,C[L-l] consist of S LDPC symbols and H Half symbols The values of S and 
H are determined from K as described below. Then L= K+S+H. 

Let 

X be the smallest positive integer such that X-iX-l) >= IK. 
S be the smallest prime integer such that S > ceil(0.01 -^ + X 
H be the smallest integer such that choose(//,ceilf///2j) >K-\-S 
H" = ceil(if/2) 
L = K+S+H 

C[0],..., C[^-l] denote the first ^ intermediate symbols 
C[K],..., C[^+5'-l] denote the S LDPC symbols, initiahsed to zero 
C[K-\-S],..., C[L-1] denote the H Half symbols, initialised to zero 
The S LDPC symbols are defined to be the values of C[K],..., C[K-\-S-l] at the end of the following process: 
For/ = 0,...,^-ldo 

a = 1 + (floor(//^) % (S-l)) 

b = i%S 

C[K+b] = C[K+b]^C[i] 

b = ib + a)%S 

C[K+b] = C[K+b]'^C[i\ 
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b = {b + a)%S 

C[K+b] = C[K+b]'^C[i\ 

The H Half symbols are defined as follows: 

Let 

g[i\ = i ^ (floor(//2)) for all positive integers / 

Note: g{i\ is the Gray sequence, in which each element differs from the previous one in a single bit 
position 

g\jM denote thej* element, 7=0, 1,2, ..., of the subsequence of ^[/] whose elements have exactly k non-zero bits in 
their binary representation 

Then, the Half symbols are defined as the values of C[K+S\..., C[L-1] after the following process: 

For/z = 0,...,if-ldo 

For; = 0,...,^+^-! do 

If bit h of g\j,H"] is equal to 1 then C[h+K+S] = C[h-\-K-\-S] ^ C\j]. 

B.5.2.4 Intermediate symbols 
B. 5.2.4.1 Definition 

Given the K source symbols C"[0], C"[l],..., C"[K-l] the L intermediate symbols C[0], C[l],..., C[L-1] are the 
uniquely defined symbol values that satisfy the following conditions: 

1. The ^source symbols C"[0], C"[l],..., C"[K-l] satisfy the ^ constraints 

C"[i] = LTEnc[^, (C[0],..., C[L-1]), (J[/], a[il b[i])l for all /, 0<i<K. 

2. The L intermediate symbols C[0], C[l],. . ., C[L-1] satisfy the pre-coding relationships defined in B.5.2.3. 

B. 5. 2. 4.2 Example method for calculation of intermediate symbols 

This sub-clause describes a possible method for calculation of the L intermediate symbols C[0], C[l],. . ., C[L-1] 
satisfying the constraints in sub-clause B.5.2.4. 1 

The generator matrix G for a code which generates A^ output symbols from K input symbols is an A^x^ matrix over 
GF(2), where each row corresponds to one of the output symbols and each column to one of the input symbols and 
where the /* output symbol is equal to the sum of those input symbols whose column contains a non-zero entry in row /. 

Then, the L intermediate symbols can be calculated as follows: 

Let 

C denote the column vector of the L intermediate symbols, C[0], C[l],. . ., C[L-1]. 

D denote the column vector consisting of S-\-H zero symbols followed by the K source symbols C"[0], C"[l], • • ., 
C"[K-1] 

Then the above constraints define an LxL matrix over GF(2), A, such that: 

AC = D 
The matrix A can be constructed as follows: 
Let: 

Gldpc be the 5" X ^ generator matrix of the LDPC symbols. So, 
Gldpc- (C[0], ..., C[K-l]f = (C[K], ..., C[K+S-l]f 
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Gnaif be the H x {K+S) generator matrix of the Half symbols, So, 

Gnaif (C[0], ..., C[S+K-\]f = iC[K+S], ..., C[K+S+H-\]f 
\s be the 5" X 5" identity matrix 
\h be the HxH identity matrix 
^sxH be the 5" X if zero matrix 

Glt be the KxL generator matrix of the encoding symbols generated by the LT Encoder. 
So, 

Glt- (C[0], -.., C[L-l]f = (C"[Ol C'Tl],..., C"[K-1] f 

i.e. Glt^j = 1 if and only if C\j] is included in the symbols which are XORed to produce LTEnc[^, (C[0], . . ., 
C[L-l]), (d[i], a[i], b[i])]. 

Then: 

The first S rows of A are equal to Gldpc I h ^'^sxh. 

The next H rows of A are equal to Gnaif 1 1//. 

The remaining K rows of A are equal to Glt- 
The matrix A is depicted in the figure below: 



K 



H 



H 



K 



Gldpc 


h 


ZsxH 


Gnaif 


I« 


Glt 



Figure B.5.2.5.2-1 : Tlie matrix A 

The intermediate symbols can then be calculated as: 

C = A D 

The source triples are generated such that for any K matrix A has full rank and is therefore invertible. This calculation 
can be realized by applying a Raptor decoding process to the K source symbols C"[0], C"[l],. . ., C"[K-\\ to produce the 
L intermediate symbols C[0], C[l ],..., C[L-1]. 

To efficiently generate the intermediate symbols from the source symbols, it is recommended that an efficient decoder 
implementation such as that described in Annex E be used. The source symbol triples are designed to facilitate efficient 
decoding of the source symbols using that algorithm. 
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B.5.3 Second encoding step: LT encoding 

In the second encoding step, the repair symbol with ESI X is generated by applying the generator LTEnc[^, (C[0], 
C[l],..., C[L-1]), (J, a, bj\ defined in sub-clause B.5.4 to the L intermediate symbols C[0], C[l],..., C[L-1] using the 
triple (J, a, h)=Tn^[K,X\ generated according to sub-clauses B3.2.2 and B.4.2. 

B.5.4 Generators 
B.5.4. 1 Random Generator 

The random number generator Rand[X, /, m] is defined as follows, where X is a non-negative integer, / is a non-negative 
integer and m is a positive integer and the value produced is an integer between and m-1. Let Vq and Vi be arrays of 
256 entries each, where each entry is a 4-byte unsigned integer. These arrays are provided in sub-clause B.7. 

Then, 

Rand[X, /, m] = (Vo[(X + /) % 256] ^ yi[(floor(X/256)+ /) % 256]) % m 

B.5.4. 2 Degree Generator 

The degree generator Deg[v] is defined as follows, where v is an integer that is at least and less than 2^^ = 1048576. 
In Table B.5.4.2-1, find the index; such that/[/-l] < v </[/] 
Dcg[v] =d\j] 

Table B.5.4.2-1 - Defines the degree distribution for encoding symbols 



Index y 


u 


*] 








- 


1 


10241 


1 


2 


491582 


2 


3 


712794 


3 


4 


831695 


4 


5 


948446 


10 


6 


1032189 


11 


7 


1048576 


40 



B.5.4. 3 LT Encoding Symbol Generator 

The encoding symbol generator LTEnc[^, (C[0], C[l],..., C[L-1]), (J, a, b)] takes the following inputs: 

K is the number of source symbols (or sub-symbols) for the source block (sub-block). Let L be derived from K as 
described in sub-clause B.5.2, and let L" be the smallest prime integer greater than or equal to L. 

(C[0], C[l],..., C[L-1]) is the array of L intermediate symbols (sub-symbols) generated as described in sub-clause 
B.5.2 

(d, a, b) is a source triple determined using the Triple generator defined in sub-clause B.5.3. 4, whereby 

d is an integer denoting an encoding symbol degree 

a is an integer between 1 and L"-l inclusive 

b is an integer between and L"-l inclusive 

The encoding symbol generator produces a single encoding symbol as output, according to the following algorithm: 
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While (b> L) do b = (b-\- a) % L" 

Let result = C[b] . 

Forj= l,...,min(J-l,L-l) do 

b = (b-\-a)% L" 

While (b> L) do b = (b-\- a) % L" 

result = result ^ C[b] 
Return result 
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B.5.4.4 Triple generator 

The triple generator Trip[^,X] takes the following inputs: 

K The number of source symbols 

X An encoding symbol ID 
Let 

L be determined from K as described in sub-clause B.5.2 

L" be the smallest prime that is greater than or equal to L 

Q = 65521, the largest prime smaller than 2^^. 

J(K) be the systematic index associated with K, as defined in sub-clause B.7 
The output of the triple generator is a triples, (J, a, b) determined as follows: 

1. A = (53591 +/(^-997)%Q 

2. B=\Q261-{J{K)+\)%Q 

3. Y={B + XA)%Q 

4. V = Rand[y, 0, 2^^] 

5. J = Deg[v] 

6. a=l+Rand[y, 1,L"-1] 

7. /? = Rand[F, 2, L"] 
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B.6 Systematic Indices J(K)) 



For each value of K the systematic index J{K) is designed to have the property that the set of source symbol triples 
((i[0], a[0], Z7[0]), . . ., (J[L-1], a[L-\], b[L-\Y) are such that the L intermediate symbols are uniquely defined, i.e. the 
matrix A in sub-clause B. 5. 2.4. 2 has full rank and is therefore invertible. 

The following is the list of the systematic indices for values of ^between 4 and 8192 inclusive, 

18, 14, 61, 46, 14, 22, 20, 40, 48, 1, 29, 40, 43, 46, 18, 8, 20, 2, 61, 26, 13, 29, 36, 19, 58, 5, 58, 0, 54, 56, 24, 14, 5, 67, 39, 31, 25, 29, 24, 19, 14, 56, 49, 49, 63, 30, 4, 39, 2, 1, 20, 19, 61, 4, 54, 70, 25, 52, 9, 26, 55, 69, 27, 68, 75, 19, 64, 57, 45, 3, 37, 31, 100, 41, 25, 41, 53, 23, 9, 31, 26, 30, 30, 46, 
90, 50, 13, 90, 77, 61, 31, 54, 54, 3, 21, 66, 21, 11, 23, 11, 29, 21, 7, 1, 27, 4, 34, 17, 85, 69, 17, 75, 93, 57, 0, 53, 71, 88, 119, 88, 90, 22, 0, 58, 41, 22, 96, 26, 79, 118, 19, 3, 81, 72, 50, 0, 32, 79, 28, 25, 12, 25, 29, 3, 37, 30, 30, 41, 84, 32, 31, 61, 32, 61, 7, 56, 54, 39, 33, 66, 29, 3, 14, 75, 75, 78, 84, 
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2423, 2601, 2285, 175, 175, 2331, 194, 3079, 384, 538, 2365, 2294, 538, 2166, 1841, 3326, 1256, 3923, 976, 85, 550, 550, 1295, 863, 863, 550, 1249, 550, 1759, 146, 1069, 920, 2633, 885, 885, 1514, 1489, 166, 1514, 2041, 885, 2456, 885, 2041, 1081, 1948, 362, 550, 94, 324, 2308, 94, 2386, 94, 
550, 874, 1329, 1759, 2280, 1487, 493, 493, 2099, 2599, 1431, 1086, 1514, 1086, 2099, 1858, 368, 1330, 2599, 1858, 2846, 2846, 2907, 2846, 713, 713, 1854, 1123, 713, 713, 3010, 1123, 3010, 538, 713, 1123, 447, 822, 555, 2011, 493, 508, 2292, 555, 1736, 2135, 2704, 555, 2814, 555, 2000, 555, 
555,822,914,327,679,327,648,537,2263,931, 1496,537, 1296, 1745, 1592, 1658, 1795,650, 1592, 1745, 1745, 1658, 1592, 1745, 1592, 1745, 1658, 1338,2124, 1592, 1745, 1745, 1745,837, 1726,2897, 1118, 1118,230, 1118, 1118, 1118, 1388, 1748,514, 128, 1165,931,514,2974,2041, 
2387, 2041, 979, 185, 36, 1269, 550, 173, 812, 36, 1165, 2676, 2562, 1473, 2885, 1982, 1578, 1578, 383, 383, 2360, 383, 1578, 2360, 1584, 1982, 1578, 1578, 1578, 2019, 1036, 355, 724, 2023, 205, 303, 355, 1036, 1966, 355, 1036, 401, 401, 401, 830, 401, 849, 578, 401, 849, 849, 578, 1776, 1123, 
552,2632,808, 1446, 1120,373, 1529, 1483, 1057,893, 1284, 1430, 1529, 1529,2632, 1352,2063, 1606, 1352, 1606,2291,3079,2291, 1529,506,838, 1606, 1606, 1352, 1529, 1529, 1483, 1529, 1606, 1529,259,902,259,902,612,612,284,398,2991, 1534, 1118, 1118, 1118, 1118, 1118,734, 
284, 2224, 398, 734, 284, 734, 398, 3031, 398, 734, 1707, 2643, 1344, 1477, 475, 1818, 194, 1894, 691, 1528, 1184, 1207, 1501, 6, 2069, 871, 2069, 3548, 1443, 2069, 2685, 3265, 1350, 3265, 2069, 2069, 128, 1313, 128, 663, 414, 1313, 414, 2000, 128, 2000, 663, 1313, 699, 1797, 550, 327, 550, 
1526, 699, 327, 1797, 1526, 550, 550, 327, 550, 1426, 1426, 1426, 2285, 1123, 890, 728, 1707, 728, 728, 327, 253, 1187, 1281, 1364, 1571, 2170, 755, 3232, 925, 1496, 2170, 2170, 1125, 443, 902, 902, 925, 755, 2078, 2457, 902, 2059, 2170, 1643, 1129, 902, 902, 1643, 1129, 606, 36, 103, 338, 
338,1089,338,338,338,1089,338,36,340,1206,1176,2041,833,1854,1916,1916,1501,2132,1736,3065,367,1934,833,833,833,2041,3017,2147,818,1397,828,2147,398,828,818,1158,818,689,327,36,1745,2132,582,1475,189,582,2132,1191,^ 

2610,2230,2230,64, 1501,537, 1501, 173,2230,2988, 1501,2694,2694,537,537, 173, 173, 1501,537,64, 173, 173,64,2230,537,2230,537,2230,2230,2069,3142, 1645,689, 1165, 1165, 1963,514,488, 1963, 1145,235, 1145, 1078, 1145,231,2405,552,21,57,57,57, 1297, 1455, 1988, 
2310, 1885, 2854, 2014, 734, 1705, 734, 2854, 734, 677, 1988, 1660, 734, 677, 734, 677, 677, 734, 2854, 1355, 677, 1397, 2947, 2386, 1698, 128, 1698, 3028, 2386, 2437, 2947, 2386, 2643, 2386, 2804, 1188, 335, 746, 1187, 1187, 861, 2519, 1917, 2842, 1917, 675, 1308, 234, 1917, 314, 314, 2339, 
2339, 2592, 2576, 902, 916, 2339, 916, 2339, 916, 2339, 916, 1089, 1089, 2644, 1221, 1221, 2446, 308, 308, 2225, 2225, 3192, 2225, 555, 1592, 1592, 555, 893, 555, 550, 770, 3622, 2291, 2291, 3419, 465, 250, 2842, 2291, 2291, 2291, 935, 160, 1271, 308, 325, 935, 1799, 1799, 1891, 2227, 1799, 
1598, 112, 1415, 1840,2014, 1822,2014,677, 1822, 1415, 1415, 1822,2014,2386,2159, 1822, 1415, 1822, 179, 1976, 1033, 179, 1840,2014, 1415, 1970, 1970, 1501,563,563,563,462,563, 1970, 1158,563,563, 1541, 1238,383,235, 1158,383, 1278,383, 1898,2938,21,2938, 1313,2201, 
2059,423,2059,1313,872,1313,2044,89,173,3327,1660,2044,1623,173,1114,1114,1592,1868,1651,1811,383,3469,1811,1651,869,383,383,1651,1651,3223,2166,3469,767,383,1811,767,2323,3355,1457,3341,2640,2976,2323,3341,2323,2640,103,103,11^ 

370, 2018, 2854, 2429, 2166, 2429, 2094, 2207, 871, 1963, 1963, 2023, 2023, 2336, 663, 2893, 1580, 691, 663, 705, 2046, 2599, 409, 2295, 1118, 2494, 1118, 1950, 549, 2494, 2453, 2046, 2494, 2453, 2046, 2453, 2046, 409, 1118, 4952, 2291, 2225, 1894, 1423, 2498, 567, 4129, 1475, 1501, 795, 

463, 2084, 828, 828, 232, 828, 232, 232, 1818, 1818, 666, 463, 232, 220, 220, 2162, 2162, 833, 4336, 913, 35, 913, 21, 2927, 886, 3037, 383, 886, 876, 1747, 383, 916, 916, 916, 2927, 916, 1747, 837, 1894, 717, 423, 481, 1894, 1059, 2262, 3206, 4700, 1059, 3304, 2262, 871, 1831, 871, 3304, 1059, 
1158,1934,1158,756,1511,41,978,1934,2603,720,41,756,41,325,2611,1158,173,1123,1934,1934,1511,2045,2045,2045,1423,3206,3691,2512,3206,2512,2000,1811,2504,2504,2611,2437,2437,2437,1455,893,150,2665,1966,605,398,2331,1^ 

760, 1292, 1962, 1373, 2000, 1990, 3684, 42, 1868, 3779, 1811, 1811, 2041, 3010, 5436, 1780, 2041, 1868, 1811, 1780, 1811, 1868, 1811, 2041, 1868, 1811, 5627, 4274, 1811, 1868, 4602, 1811, 1811, 1474, 2665, 235, 1474, 2665 
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B.7 Random Numbers 



The two tables Vq and Vi described in sub-clause B.5.4.1 are given below. Each entry is a 32-bit integer in decimal 
representation. 



B.7.1 The table \/o 



251291136, 3952231631, 3370958628, 4070167936, 123631495, 3351110283, 3218676425, 2011642291, 774603218, 2402805061, 1004366930, 1843948209, 428891132, 3746331984, 1591258008, 3067016507, 1433388735, 504005498, 2032657933, 3419319784, 
2805686246,3102436986,3808671154,2501582075,3978944421,246043949,4016898363, 649743608, 1974987508,2651273766, 2357956801, 689605112, 715807172,2722736134, 191939188, 3535520147,3277019569, 1470435941,3763101702,3232409631, 
122701163,3920852693, 782246947, 372121310,2995604341, 2045698575,2332962102,4005368743, 218596347,3415381967, 4207612806, 861117671,3676575285,2581671944,3312220480, 681232419, 307306866,4112503940,1158111502, 709227802, 
2724140433,4201101115,4215970289,4048876515,3031661061, 1909085522, 510985033,1361682810, 129243379,3142379587, 2569842483,3033268270,1658118006, 932109358,1982290045, 2983082771,3007670818,3448104768, 683749698, 778296777, 
1399125101, 1939403708, 1692176003,3868299200, 1422476658, 593093658, 1878973865,2526292949, 1591602827,3986158854, 3964389521,2695031039, 1942050155, 424618399, 1347204291, 2669179716,2434425874,2540801947, 1384069776,4123580443, 
1523670218,2708475297, 1046771089,2229796016, 1255426612, 4213663089, 1521339547,3041843489, 420130494, 10677091, 515623176,3457502702,2115821274,2720124766,3242576090, 854310108, 425973987, 325832382, 1796851292,2462744411, 
1976681690, 1408671665, 1228817808,3917210003, 263976645, 2593736473,2471651269,4291353919, 650792940, 1191583883, 3046561335,2466530435,2545983082, 969168436,2019348792, 2268075521, 1169345068,3250240009,3963499681,2560755113, 
911182396, 760842409,3569308693,2687243553, 381854665,2613828404,2761078866, 1456668111, 883760091,3294951678, 1604598575, 1985308198, 1014570543,2724959607,3062518035, 3115293053, 138853680,4160398285,3322241130,2068983570, 
2247491078,3669524410, 1575146607, 828029864,3732001371, 3422026452,3370954177,4006626915, 543812220, 1243116171, 3928372514,2791443445,4081325272,2280435605, 885616073, 616452097,3188863436,2780382310,2340014831, 1208439576, 
258356309,3837963200,2075009450,3214181212,3303882142, 880813252,1355575717, 207231484,2420803184, 358923368, 1617557768,3272161958,1771154147,2842106362,1751209208, 1421030790, 658316681, 194065839,3241510581, 38625260, 
301875395,4176141739, 297312930,2137802113, 1502984205, 3669376622,3728477036, 234652930,2213589897,2734638932, 1129721478,3187422815,2859178611,3284308411,3819792700, 3557526733, 451874476, 1740576081,3592838701, 1709429513, 
3702918379,3533351328, 1641660745, 179350258,2380520112, 3936163904,3685256204,3156252216, 1854258901, 2861641019,\ 3176611298, 834787554, 331353807, 517858103,3010168884, 4012642001,2217188075,3756943137,3077882590,2054995199, 
3081443129,3895398812,1141097543,2376261053,2626898255, 2554703076, 401233789,1460049922, 678083952,1064990737, 940909784,1673396780, 528881783,1712547446,3629685652, 1358307511 



B.7.2 The table V^ 



807385413,2043073223,3336749796, 1302105833,2278607931, 541015020, 1684564270, 372709334,3508252125, 1768346005, 1270451292,2603029534,2049387273,3891424859,2152948345, 4114760273, 915180310,3754787998, 700503826,2131559305, 
1308908630, 224437350,4065424007,3638665944, 1679385496, 3431345226, 1779595665,3068494238, 1424062773, 1033448464, 4050396853,3302235057, 420600373,2868446243, 311689386, 259047959,4057180909, 1575367248,4151214153, 110249784, 
3006865921,4293710613,3501256572, 998007483, 499288295, 1205710710,2997199489, 640417429,3044194711, 486690751, 2686640734,2394526209,2521660077, 49993987,3843885867, 4201106668, 415906198, 19296841,2402488407,2137119134, 
1744097284, 579965637,2037662632, 852173610,2681403713, 1047144830,2982173936, 910285038,4187576520,2589870048, 989448887,3292758024, 506322719, 176010738,1865471968, 2619324712, 564829442,1996870325, 339697593,4071072948, 
3618966336,2111320126,1093955153, 957978696, 892010560, 1854601078,1873407527,2498544695,2694156259,1927339682, 1650555729, 183933047,3061444337,2067387204, 228962564, 3904109414,1595995433,1780701372,2463145963, 307281463, 
3237929991, 3852995239, 2398693510, 3754138664, 522074127, 146352474, 4104915256, 3029415884, 3545667983, 332038910, 976628269, 3123492423, 3041418372, 2258059298, 2139377204, 3243642973, 3226247917, 3674004636, 2698992189, 3453843574, 
1963216666,3509855005,2358481858, 747331248, 1957348676, 1097574450,2435697214,3870972145, 1888833893,2914085525, 4161315584, 1273113343,3269644828,3681293816, 412536684, 1156034077,3823026442, 1066971017,3598330293, 1979273937, 
2079029895, 1195045909, 1071986421,2712821515,3377754595, 2184151095, 750918864,2585729879,4249895712, 1832579367, 1192240192, 946734366, 31230688,3174399083,3549375728, 1642430184, 1904857554, 861877404,3277825584,4267074718, 
3122860549, 666423581, 644189126, 226475395, 307789415, 1196105631,3191691839, 782852669,1608507813,1847685900, 4069766876,3931548641,2526471011, 766865139,2115084288, 4259411376,3323683436, 568512177,3736601419,1800276898, 
4012458395, 1823982, 27980198, 2023839966, 869505096, 431161506, 1024804023, 1853869307, 3393537983, 1500703614, 3019471560, 1351086955, 3096933631, 3034634988, 2544598006, 1230942551, 3362230798, 159984793, 491590373, 3993872886, 
3681855622, 903593547,3535062472,1799803217, 772984149, 895863112,1899036275,4187322100, 101856048, 234650315, 3183125617,3190039692, 525584357,1286834489, 455810374, 1869181575, 922673938,3877430102,3422391938,1414347295, 
1971054608,3061798054, 830555096,2822905141, 167033190, 1079139428,4210126723,3593797804, 429192890, 372093950, 1779187770,3312189287, 204349348, 452421568,2800540462, 3733109044,1235082423,1765319556,3174729780,3762994475, 
3171962488, 442160826, 198349622, 45942637,1324086311, 2901868599, 678860040,3812229107, 19936821,1119590141, 3640121682,3545931032,2102949142,2828208598,3603378023, 4135048896 



B.8 VOID 
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Annex C (informative): 
lANA registration 

This annex provides the required lANA registration. 



C.1 Registration of SDP Protocol Identifiers for Source 
packet 

This specification defines two new SDP protocol identificators for source packets. As the registration rules requires 
these to be registered by an RFC, there will be an RFC referencing the definitions here. 

Protocol identifier 'UDP/MBMS-FEC/RTP/AVP' identifies a protocol combination of UDP[7], FEC source packets (see 
sub-clause 8.2.2.4), RTP [6] using the AVP profile [78]. This protocol identifier shall use the FMT space rules that are 
used for RTP/AVP. 

Protocol identifier 'UDP/MBMS-FEC/RTP/SAVP' identifies a protocol combination of UDP [7], FEC source packets 
(see sub-clause 8.2.2.4), and RTP [6] using the SAVP profile [77]. This protocol identifier shall use the FMT space 
rules that are used for RTP/AVP. 



C.2 Registration of SDP Protocol identifier for repair 
packets 

This specification defines one new SDP protocol identificator for FEC repair packets. As the registration rules requires 
these to be registered by an RFC, there will be an RFC referencing the definitions within this specification. 

Protocol identifier 'UDP/MBMS-REPAIR' identifies a protocol combination of UDP [7], FEC repair packets (see sub- 
clause 8.2.2.4). The FMT string is not used and shall be set to '*'. 



C.3 Registration of MIME type 

"application/simpleSymbolContainer" 

The MIME Type "application/simpleSymbolContainer" denotes that the message body is a simple container of 
encoding symbols for the file repair procedure (clause 9.3.5.2 - File Repair Response Message Format for HTTP 
Carriage of Repair Data). 

Type name: application 

Subtype name: simpleSymbolContainer 

Required parameters: 

None 
Optional parameters: 

None 

Encoding considerations: 

The content is binary and if transported in a protocol not capable of handling binary content then the object must 
be encoded, for example using base64 [82]. 



ETSI 



3GPP TS 26.346 version 6.10.0 Release 6 107 ETSI TS 126 346 V6.10.0 (2007-10) 

Security considerations: 

The content of this media type are either source or repair symbols part of a binary file object. Thus it security 
considerations depends on the security requirements on the file object. As modification of the response message 
may corrupt the complete file object due to the FEC repair operations, integrity protection is recommended. 
Source authentication is also recommended to prevent man in the middle or spoofing attacks resulting in 
erronous repair symbols. 

Interoperability considerations: 

None 
Published specification: 

3GPP TS 26.346 
Applications which use this media type: 

3GPP MBMS based apphcations 

Additional information: 

Magic number(s): None 

File extension(s): 

Macintosh file type code(s): 

Person & email address to contact for further information: 

Magnus Westerlund (magnus.westerlund@ericsson.com) 
3GPP TSG SA WG4 

Intended usage: COMMON 

Restrictions on usage: 

None 
Author: 

3GPP TSG SA WG4 
Change controller: 

3GPP TSG SA WG4 



C.4 Registration of MIME type "application/mbms-user- 
service-description+xml " 

The MIME Type "application/mbms-user-service-description+xml" denotes that the message body is a user service 
description instance in accordance with the XML schema "urn:3GPP:metadata:2005:MBMS:userServiceDescription" 
(see sub-clause 11.2.1). 

Type name: application 

Subtype name: mbms-user-service-description+xml 

Required parameters: 

None 

Optional parameters: 

charset: As specified in RFC 3023 [83] for media type application/xml. 
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Encoding considerations: 

This is an XML document and the encoding considerations are the same as for media type "apphcation/xml" 
defined in RFC 3023 [83]. 

Security considerations: 

This media format is used to configure the receiver on how to participate in a service. This format is highly 
suspectible to manipulation or spoofing for attacks desring to misslead a receiver about a session. Both integrity 
protection and source authentication is recommended to prevent missleading of the receiver. 

Interoperability considerations: 

None 
Published specification: 

3GPP TS 26.346 
Applications which use this media type: 

3GPP MBMS based apphcations 

Additional information: 

Magic number(s): None 

File extension(s): 

Macintosh file type code(s): 

Person & email address to contact for further information: 

Magnus Westerlund (magnus.westerlund@ericsson.com) 
3GPP TSG SA WG4 

Intended usage: COMMON 

Restrictions on usage: None 

Author: 

3GPP TSG SA WG4 
Change controller: 

3GPP TSG SA WG4 



C.5 Registration of MIME type 

"application/mbms-envelope+xml " 

The MIME Type "application/mbms-envelope+xml" denotes that the message body is a metadata envelope according to 
the XML schema "urn:3gpp:metadata:2005:MBMS:envelope" (see sub-clause 11.1.3). 

Type name: application 

Subtype name: mbms-envelope+xml 

Required parameters: 

None 

Optional parameters: 
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embedded: Declares if all objects described in this envelope instance are embedded within the this envelope 
instance. The value is either (false) or 1 (true) and when this parameter is omitted the value 
defaults to (false). 

referenced: Declares if all objects described in this envelope instance are referenced, none is embedded within 
the envelope. The value is either (false) or 1 (true) and when this parameter is omitted the value 
defaults to (false). 

charset: As specified in RFC 3023 [83] for media type application/xml. 

Encoding considerations: 

This is an XML document and the encoding considerations are the same as for media type "application/xml" 
defined in RFC 3023 [83]. 

Security considerations: 

This media format contains information about versioning and validity of files, telling the receiver if it should 
invalidate already received files or replace previously received files with new version contained or referenced 
within this format. Thus modifying or spoofing an envelope is a simple way of making denial of service attack. 
Thus source authentication and integrity protection of the files are recommended. 

Interoperability considerations: 

None 
Published specification: 

3GPP TS 26.346 
Applications which use this media type: 

3GPP MBMS based apphcations 

Additional information: 

Magic number(s): None 

File extension(s): 

Macintosh file type code(s): 

Person & email address to contact for further information: 

Magnus Westerlund (magnus.westerlund@ericsson.com) 
3GPP TSG SA WG4 

Intended usage: COMMON 

Restrictions on usage: 

Author: 

3GPP TSG SA WG4 
Change controller: 

3GPP TSG SA WG4 
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C.6 Registration of IVIIIVIE type 

"application/mbms-protection-description+xml " 

The MIME-Type "application/mbms-protection-description+xml" denotes that the message body is an MBMS 
protection description XML document according to the scheme identified as 
"urn:3GPP:metadata:2005:MBMS:securityDescription" (see sub-clause 11.3.1). 

Type name: application 

Subtype name: mbms-protection-description+xml 

Required parameters: 

None 
Optional parameters: 

charset: As specified in RFC 3023 [83] for media type application/xml. 

Encoding considerations: 

This is an XML document and the encoding considerations are the same as for media type "application/xml" 
defined in RFC 3023 [83]. 

Security considerations: 

The media format is used to configure the security functions of the MBMS delivery. Thus a target for any 
attacker that would like modify a receivers understanding of the security functions, either for a denial of service 
attack or a session replacement attack. However the format contains no seceret information that may not be 
shared openly. All security keys are handled using other mechanisms. Source authentication and integrity 
protection is recommended. 

Interoperability considerations: 

None 
Published specification: 

3GPP TS 26.346 
Applications which use this media type: 

3GPP MBMS based apphcations 

Additional information: 

Magic number(s): None 

File extension(s): 

Macintosh file type code(s): 

Person & email address to contact for further information: 

Magnus Westerlund (magnus.westerlund@ericsson.com) 
3GPP TSG SA WG4 

Intended usage: COMMON 

Restrictions on usage: 

Author: 

3GPP TSG SA WG4 

Change controller: 
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3GPP TSG SA WG4 

C.7 Registration of IVIIIVIE type 

"application/mbms-associated-procedure- 
description+xml" 

The MIME-Type "application/mbms-associated-procedure-description+xml" denotes that the message body contains 
the associated procedure description in XML following the schema 
"urn:3gpp:metadata:2005:MBMS:associatedProcedure" (see sub-clause 9.5.1). 

Type name: application 

Subtype name: mbms-associated-procedure-description+xml 

Required parameters: 

None 
Optional parameters: 

charset: As specified in RFC 3023 [83] for media type application/xml. 

Encoding considerations: 

This is an XML document and the encoding considerations are the same as for media type "application/xml" 
defined in RFC 3023 [83]. 

Security considerations: 

The information present in this media format is used to configure the receiving application. Thus the usage of the 
fomat is vulnerable to attacks modifying or spoofing the content of this format. It is recommended to use source 
authentication and integrity protection. 

Interoperability considerations: 

None 
Published specification: 

3GPP TS 26.346 
Applications which use this media type: 

3GPP MBMS based apphcations 

Additional information: 

Magic number(s): None 

File extension(s): 

Macintosh file type code(s): 

Person & email address to contact for further information: 

Magnus Westerlund (magnus.westerlund@ericsson.com) 
3GPP TSG SA WG4 

Intended usage: COMMON 

Restrictions on usage: 

Author: 
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C.8 Registration of MIME type "application/mbms- 
msk+xml" 

The MIME-Type "application/ mbms-msk+xml" denotes that the message body contains the MSK request parameters 
in accordance with the XML scheme "urn:3GPP:metadata:2005:MBMS:mskRequest" (see sub-clause 11.6 and 3GPP 
TS 33.246 [20]). 

Type name: application 

Subtype name: application/mbms-msk+xml 

Required parameters: 

None 
Optional parameters: 

charset: As specified in RFC 3023 [83] for media type application/xml. 

Encoding considerations: 

This is an XML document and the encoding considerations are the same as for media type "application/xml" 
defined in RFC 3023 [83]. 

Security considerations: 

The usage of the format is to identify one or more MSK that the requesting entity desires to receive. 
Modification or changes to this format thus only result in a denial of service attack. Integrity protection would 
protect against such modifications. 

Interoperability considerations: 

None 
Published specification: 

3GPP TS 26.346 
Applications which use this media type: 

3GPP MBMS based apphcations 

Additional information: 

Magic number(s): None 

File extension(s): 

Macintosh file type code(s): 

Person & email address to contact for further information: 

Magnus Westerlund (magnus.westerlund@ericsson.com) 
3GPP TSG SA WG4 

Intended usage: COMMON 

Restrictions on usage: 
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C.9 Registration of MIME type "application/mbms- 
register+xml" 

The MIME-Type "application/mbms-register+xml" denotes that the message body contains the MBMS User Service 
Registration parameters in accordance with the XML schema "urn:3GPP:metadata:2005:MBMS:securityRegistration" 
(see sub-clause 11.4 and 3GPP TS 33.246 [20]). 

Type name: application 

Subtype name: mbms -register +xml 

Required parameters: 

None 
Optional parameters: 

charset: As specified in RFC 3023 [83] for media type application/xml. 

Encoding considerations: 

This is an XML document and the encoding considerations are the same as for media type "application/xml" 
defined in RFC 3023 [83]. 

Security considerations: 

The content of this format identifies a user service that the document creator desires to register to. Any 
modificatons of this document would allow an attacker to change to what services the creator registers to. To 
prevent this integrity protection is necessary. There is also necessary to authenticate the entity performing the 
registration to know who is the one performing the registration request. In MBMS this is accomplished using 
procedures described in 3GPP TS 33.246. 

Interoperability considerations: 

None 
Published specification: 

3GPP TS 26.346 
Applications which use this media type: 

3GPP MBMS based apphcations 
Additional information: 
Magic number(s): None 
File extension(s): 
Macintosh file type code(s): 
Person & email address to contact for further information: 
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Magnus Westerlund (magnus.westerlund@ericsson.com) 
3GPP TSG SA WG4 

Intended usage: COMMON 

Restrictions on usage: 

None 
Author: 

3GPP TSG SA WG4 
Change controller: 

3GPP TSG SA WG4 



C.10 Registration of MIME type "application/mbms- 
deregister+xml" 

The MIME-Type "application/mbms-deregister+xml" denotes that the message body contains the MBMS User Service 
Deregistration parameters in accordance with the XML schema 

"urn:3GPP:metadata:2005:MBMS:securityDeregistration" (see sub-clause 11.5 of 3GPP TS 26.346 and 3GPP 
TS 33.246 [20]). 

Type name: application 

Subtype name: mbms-deregister+xml 

Required parameters: 

None 
Optional parameters: 

charset: As specified in RFC 3023 [83] for media type application/xml. 

Encoding considerations: 

This is an XML document and the encoding considerations are the same as for media type "application/xml" 
defined in RFC 3023 [83]. 

Security considerations: 

The content of this format identifies a user service that the document creator desires to register to. Any 
modificatons of this document would allow an attacker to change to what services the creator registers to. To 
prevent this integrity protection is necessary. There is also necessary to authenticate the entity performing the 
registration to know who is the one performing the registration request. In MBMS this is accomplished using 
procedures described in 3GPP TS 33.246. 

Interoperability considerations: 

None 
Published specification: 

3GPP TS 26.346 
Applications which use this media type: 

3GPP MBMS based apphcations 
Additional information: 



ETSI 



3GPP TS 26.346 version 6.10.0 Release 6 



115 



ETSI TS 126 346 V6.10.0 (2007-10) 



Magic number(s): None 

File extension(s): 

Macintosh file type code(s): 

Person & email address to contact for further information: 

Magnus Westerlund (magnus.westerlund@ericsson.com) 
3GPP TSG SA WG4 

Intended usage: COMMON 

Restrictions on usage: 

None 
Author: 

3GPP TSG SA WG4 
Change controller: 

3GPP TSG SA WG4 



C.1 1 Registration of MIME type "application/mbms- 
reception-report+xml" 

The MIME-type registration for "application/mbms-reception-report+xml" that identifies XML documents that 
follows the schema "urn: 3gpp:metadata: 2005 :MBMS:receptionreport" defined in clause 9.5.3. 

Type name: application 

Subtype name: mbms-reception-report+xml 

Required parameters: 

None 
Optional parameters: 

charset: As specified in RFC 3023 [83] for media type application/xml. 

Encoding considerations: 

This is an XML document and the encoding considerations are the same as for media type "application/xml" 
defined in RFC 3023 [83]. 

Security considerations: 

The reception report XML document instances contain information about what services and files that a particular 
receiver has received. Thus to prevent manipulation of that information it would need to be integrity protected. 
The information also has privacy relevance as it reveals what a specific receiver, which usually can be connected 
to a specific user, has received. 

Interoperability considerations: 

None 
Published specification: 

3GPP TS 26.346 
Applications which use this media type: 
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3GPP MBMS based applications 
Additional information: 

None 

Person & email address to contact for further information: 

Magnus Westerlund (magnus.westerlund@ericsson.com) 
3GPP TSG SA WG4 

Intended usage: COMMON 

Restrictions on usage: 

None 
Author: 

3GPP TSG SA WG4 
Change controller: 

3GPP TSG SA WG4 



C.12 Registration of MIME type "application/mbms-msk- 
response+xml" 

The MIME Media Type "application/ mbms-msk-response+xml" denotes that the message body contains the response 
codes to MSK request procedure in accordance with the XML scheme 
"urn:3GPP:metadata:2005:MBMS:mskResponse" (see sub-clause 11.8 and 3GPPTS 33.246 [20]). 

Type name: application 

Subtype name: mbms-msk-response+xml 

Required parameters: 

None 
Optional parameters: 

charset: As specified in RFC 3023 [83] for media type application/xml. 

Encoding considerations: 

This is an XML document and the encoding considerations are the same as for media type "application/xml" 
defined in RFC 3023 [83]. 

Security considerations: 

The usage of the format is to identify one or more response codes of MSK requests procedures. Modification or 
changes to this format thus only result in a denial of service attack. Integrity protection would protect against 
such modifications. In MBMS this is accomplished using procedures described in 3GPP TS 33.246. 

Interoperability considerations: 

None 
Published specification: 

3GPP TS 26.346 
Applications which use this media type: 
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3GPP MBMS based applications 

Additional information: 

Magic number(s): None 

File extension(s): 

Macintosh file type code(s): 

Person & email address to contact for further information: 

Magnus Westerlund (magnus.westerlund@ericsson.com) 
3GPP TSG SA WG4 

Intended usage: COMMON 

Restrictions on usage: 

None 
Author: 

3GPP TSG SA WG4 
Change controller: 

3GPP TSG SA WG4 



C.13 Registration of MIME type "application/mbms- 
register-response+xml" 

The MIME Media Type "application/mbms-register-response+xml" denotes that the message body contains the 
response codes to an MBMS User Service Registration or MBMS User Service De-Register procedure in accordance 
with the XML schema "urn:3GPP:metadata:2005:MBMS:securityRegistrationResponse" (see sub-clause 11.7 and 
3GPPTS 33.246 [20]). 

Type name: application 

Subtype name: mbms-register-response+xml 

Required parameters: 

None 
Optional parameters: 

charset: As specified in RFC 3023 [83] for media type application/xml. 

Encoding considerations: 

This is an XML document and the encoding considerations are the same as for media type "application/xml" 
defined in RFC 3023 [83]. 

Security considerations: 

The usage of the format is to identify one or more response codes of registration or deregistration procedures. 
Modification or changes to this format thus only result in a denial of service attack. Integrity protection would 
protect against such modifications. In MBMS this is accomplished using procedures described in 3GPP TS 
33.246 

Interoperability considerations: 

None 
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Published specification: 

3GPP TS 26.346 
Applications which use this media type: 

3GPP MBMS based apphcations 

Additional information: 

Magic number(s): None 

File extension(s): 

Macintosh file type code(s): 

Person & email address to contact for further information: 

Magnus Westerlund (magnus.westerlund@ericsson.com) 
3GPP TSG SA WG4 

Intended usage: COMMON 

Restrictions on usage: 

None 
Author: 

3GPP TSG SA WG4 
Change controller: 

3GPP TSG SA WG4 
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Annex D (informative): 
RTP packetization guidelines 



This annex provides guidelines for MBMS senders to minimize initial buffering delay between starting of the reception 
and starting of rendering of media data in MBMS receivers: When H.264 (AVC) video is in use, an MBMS sender 
should form FEC source blocks in which the first H.264 (AVC) access unit in decoding order is an IDR access unit. 

MBMS senders should transmit all application data units for a given H.264 (AVC) access unit, or audio frame within 
one FEC source block. 

MBMS senders should set the min-buffer-time MIME/SDP parameter and the minimum buffering delay elements 
included in FEC source blocks to values that are sufficient to cover any required de-interleaving of application data 
units, such as H.264 (AVC) NAL units and coded audio frames, from their transmission order to decoding order. 

When RTP timestamps are converted to the wallclock time of the MBMS receiver, the smallest RTP timestamp among 
the FEC source packets of a FEC source block of a stream should be equal or close to the smallest RTP timestamp 
among the FEC source packets of a FEC source block of any other stream of the same MBMS streaming session. 

When RTP timestamps are converted to the wallclock time of the MBMS receiver, the greatest RTP timestamp among 
the FEC source packets of a FEC source block of a stream should be equal or close to the greatest RTP timestamp 
among the FEC source packets of a FEC source block of any other stream of the same MBMS streaming session. 
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Annex E (informative): Example FEC decoder 
E.1 General 

This clause describes an efficient decoding algorithm for the Raptor codes described in this specification. Note that each 
received encoding symbol can be considered as the value of an equation amongst the intermediate symbols. From these 
simultaneous equations, and the known pre-coding relationships amongst the intermediate symbols, any algorithm for 
solving simultaneous equations can successfully decode the intermediate symbols and hence the source symbols. 
However, the algorithm chosen has a major effect on the computational efficiency of the decoding. 

E.2 Decoding a source block 
E.2.1 General 

It is assumed that the decoder knows the structure of the source block it is to decode, including the symbol size, T, and 
the number K of symbols in the source block. 

From the algorithms described in Sub-clauses B.5, the Raptor decoder can calculate the total number L = K+S+H of pre- 
coding symbols and determine how they were generated from the source block to be decoded. In this description it is 
assumed that the received encoding symbols for the source block to be decoded are passed to the decoder. Furthermore, 
for each such encoding symbol it is assumed that the number and set of intermediate symbols whose exclusive-or is 
equal to the encoding symbol is passed to the decoder. In the case of source symbols, the source symbol triples 
described in Sub-clause B.5. 2. 2 indicate the number and set of intermediate symbols which sum to give each source 
symbol. 

Let A^ > ^ be the number of received encoding symbols for a source block and let M = S-\-H-\-N. The following M by L 
bit matrix A can be derived from the information passed to the decoder for the source block to be decoded. Let C be the 
column vector of the L intermediate symbols, and let D be the column vector of M symbols with values known to the 
receiver, where the first S-\-H of the M symbols are zero-valued symbols that correspond to LDPC and Half symbols 
(these are check symbols for the LDPC and Half symbols, and not the LDPC and Half symbols themselves), and the 
remaining A^ of the M symbols are the received encoding symbols for the source block. Then, A is the bit matrix that 
satisfies A-C = D, where here • denotes matrix multiplication over GF[2]. In particular, A[iJ] = 1 if the intermediate 
symbol corresponding to index 7 is exclusive-ORed into the LDPC, Half or encoding symbol corresponding to index / in 
the encoding, or if index / corresponds to a LDPC or Half symbol and index j corresponds to the same LDPC or Half 
symbol. For all other / and j, A[iJ] = 0. 

Decoding a source block is equivalent to decoding C from known A and D. It is clear that C can be decoded if and only 
if the rank of A over GF[2] is L. Once C has been decoded, missing source symbols can be obtained by using the source 
symbol triples to determine the number and set of intermediate symbols which must be exclusive-ORed to obtain each 
missing source symbol. 

The first step in decoding C is to form a decoding schedule. In this step A is converted, using Gaussian elimination 
(using row operations and row and column reorderings) and after discarding M-L rows, into the L by L identity matrix. 
The decoding schedule consists of the sequence of row operations and row and column re-orderings during the 
Gaussian elimination process, and only depends on A and not on D. The decoding of C from D can take place 
concurrently with the forming of the decoding schedule, or the decoding can take place afterwards based on the 
decoding schedule. 

The correspondence between the decoding schedule and the decoding of C is as follows. Let c[0] = 0, c[l] = 1 . ..,c[L- 
1] =L-1 and(i[0] =0, J[l] = l...,J[M-l] =M-1 initially. 

• Each time row / of A is exclusive-ORed into row /" in the decoding schedule then in the decoding process 
symbol /)[J[/]] is exclusive-ORed into symbol /)[J[/"]] . 

• Each time row / is exchanged with row /" in the decoding schedule then in the decoding process the value of 
d[i] is exchanged with the value of J[/"]. 

• Each time column j is exchanged with column/' in the decoding schedule then in the decoding process the 
value of c\j] is exchanged with the value of c[/"]. 
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From this correspondence it is clear that the total number of exclusive-ORs of symbols in the decoding of the source 
block is the number of row operations (not exchanges) in the Gaussian elimination. Since A is the L by L identity 
matrix after the Gaussian elimination and after discarding the last M-L rows, it is clear at the end of successful 
decoding that the L symbols Z)[(i[0]], Z)[(i[l]],..., D[d[L-\]] are the values of the L symbols C[c[0]], C[c[l]],..., C[c[L- 
1]]. 

The order in which Gaussian elimination is performed to form the decoding schedule has no bearing on whether or not 
the decoding is successful. However, the speed of the decoding depends heavily on the order in which Gaussian 
elimination is performed. (Furthermore, maintaining a sparse representation of A is crucial, although this is not 
described here). The remainder of this clause describes an order in which Gaussian elimination could be performed that 
is relatively efficient. 

E.2.2 First Phase 

The first phase of the Gaussian elimination the matrix A is conceptually partitioned into submatrices. The submatrix 
sizes are parameterized by non-negative integers / and u which are initialized to 0. The submatrices of A are: 

(1) The submatrix I defined by the intersection of the first / rows and first / columns. This is the identity matrix at 
the end of each step in the phase. 

(2) The submatrix defined by the intersection of the first / rows and all but the first / columns and last u columns. 
All entries of this submatrix are zero. 

(3) The submatrix defined by the intersection of the first / columns and all but the first / rows. All entries of this 
submatrix are zero. 

(4) The submatrix U defined by the intersection of all the rows and the last u columns. 

(5) The submatrix V formed by the intersection of all but the first / columns and the last u columns and all but the 
first / rows. 

Figure B22-\ illustrates the submatrices of A. At the beginning of the first phase V = A. In each step, a row of A is 
chosen. 



Identity matrix 
I 


All zeroes 


u 


All zeroes 


V 



Figure E.2.2-1 - Submatrices of A in the first phase 

The following graph defined by the structure of V is used in determining which row of A is chosen. The columns that 
intersect V are the nodes in the graph, and the rows that have exactly 2 ones in V are the edges of the graph that connect 
the two columns (nodes) in the positions of the two ones. A component in this graph is a maximal set of nodes 
(columns) and edges (rows) such that there is a path between each pair of nodes/edges in the graph. The size of a 
component is the number of nodes (columns) in the component. 



ETSI 



3GPP TS 26.346 version 6.1 0.0 Release 6 1 22 ETSI TS 1 26 346 V6.1 0.0 (2007-1 0) 

There are at most L steps in the first phase. The phase ends successfully when i-\- u = L, i.e., when V and the all zeroes 
submatrix above V have disappeared and A consists of I, the all zeroes submatrix below I, and U. The phase ends 
unsuccessfully in decoding failure if at some step before V disappears there is no non-zero row in V to choose in that 
step. In each step, a row of A is chosen as follows: 

If all entries of V are zero then no row is chosen and decoding fails. 

- Let r be the minimum integer such that at least one row of A has exactly r ones in V. 

- If r 7^ 2 then choose a row with exactly r ones in V with minimum original degree among all such rows. 

If r = 2 then choose any row with exactly 2 ones in V that is part of a maximum size component in the graph 
described above which is defined by V. 

After the row is chosen in this step the first row of A that intersects V is exchanged with the chosen row so that the 
chosen row is the first row that intersects V. The columns of A among those that intersect V are reordered so that one 
of the r ones in the chosen row appears in the first column of V and so that the remaining r-1 ones appear in the last 
columns of V. Then, the chosen row is exclusive-ORed into all the other rows of A below the chosen row that have a 
one in the first column of V. Finally, / is incremented by 1 and u is incremented by r-1, which completes the step. 

E.2.3 Second Phase 

The submatrix U is further partitioned into the first / rows, Uupper, and the remaining M - i rows, Uiower- Gaussian 
elimination is performed in the second phase on Uiower to either determine that its rank is less than u (decoding failure) 
or to convert it into a matrix where the first u rows is the identity matrix (success of the second phase). Call this uhy u 
identity matrix \. The M-L rows of A that intersect Uiower - \ are discarded. After this phase A has L rows and L 
columns. 

E.2.4 Third Phase 

After the second phase the only portion of A which needs to be zeroed out to finish converting A into the L by L 
identity matrix is Uupper- The number of rows / of the submatrix Uupper is generally much larger than the number of 
columns u of Uupper- To zero out Uupper efficiently, the following precomputation matrix U" is computed based on 1^ in 
the third phase and then U" is used in the fourth phase to zero out Uupper- The u rows of \u are partitioned into ceil(w/8) 
groups of 8 rows each, except the last group, which may have less than 8 rows. Then, for each group of rows all non- 
zero combinations of the rows are computed, resulting in at most 2^ - 1 = 255 rows (this can be done with at most 2^-8-1 
= 247 exclusive-ors of rows per group, since the combinations of Hamming weight one that appear in \ do not need to 
be recomputed). Thus, the resulting precomputation matrix U" has at most ceil(w/8) -255 rows and u columns. Note 
that U" is not formally a part of matrix A, but will be used in the fourth phase to zero out Uupper- Note that the purpose 
of constructing the precomputation matrix U" is that the total number of exclusive OR operations between symbols that 
accompany the fouth phase of zeroing out Uupper is generally less than if the entries of Uupper were zeroed individually. 

E.2.5 Fourth Phase 

For each of the first / rows of A, for each group of 8 columns in the UupperSubmatrix of this row, if the set of 8 column 
entries in Uupper are not all zero then the row of the precomputation matrix U" that matches the pattern in the 8 columns 
is exclusive-ORed into the row, thus zeroing out those 8 columns in the row at the cost of exclusive-oring one row of 
U"into the row. 

After this phase A is the L by L identity matrix and a complete decoding schedule has been successfully formed. Then, 
as explained in Sub-clause C.2.1, the corresponding decoding consisting of exclusive-ORing known encoding symbols 
can be executed to recover the intermediate symbols based on the decoding schedule. 

The triples associated with all source symbols are computed according to B.5.2.2.The triples for received source 
symbols are used in the decoding. The triples for missing source symbols are used to determine which intermediate 
symbols need to be exclusive-ORed to recover the missing source symbols. 
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